Rumah > pangkalan data > tutorial mysql > MYSQL显示行号排序、同张表数据排序上下进行比较

MYSQL显示行号排序、同张表数据排序上下进行比较

php是最好的语言
Lepaskan: 2018-07-26 17:45:41
asal
1805 orang telah melayarinya

  • 需求

  1. 需要查询小说是否有断更,小说章节信息表中有发布时间:pub_time,如果发布时间间隔超过三天就算断更

  • 思路

    1. 查询小说章节信息表,将章节信息按照发布时间排序,加上行号。生成table1 和table2 信息一样

    2. left join 关联查询,table1行号为 n 与 table2行号为n+1的数据发布时间比较,如果存在大于三天则说明断更

  • 准备工作

  • 章节表:

    CREATE TABLE `t_chapter` (  `id` varchar(255) NOT NULL COMMENT '主键',  `auto_code` varchar(255) NOT NULL COMMENT '编号',  `production_number` varchar(11) NOT NULL COMMENT '作品编号',  `pub_time` datetime DEFAULT NULL COMMENT '发布时间',  PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8
    Salin selepas log masuk
    Salin selepas log masuk
    • 开始

      1. 对章节表根据发布时间升序排序并显示行号

            SELECT
                t.auto_code ,
                t.id ,
                t.production_number ,
                t.pub_time ,
                (@rowNum :=@rowNum + 1) AS rowNo        FROM
                t_chapter t ,
                (SELECT(@rowNum := 0)) b        WHERE 
               t.production_number = 1414(指定作品)        ORDER BY
                t.pub_time ASC
    Salin selepas log masuk
    Salin selepas log masuk

    查询结果已经按照发布时间排序
    q.png

    • 关联查询

        SELECT
            count(1)    FROM
            (            SELECT
                    t.auto_code ,
                    t.id ,
                    t.production_number ,
                    t.pub_time ,
                    (@rowNum :=@rowNum + 1) AS rowNo            FROM
                    t_chapter t ,
                    (SELECT(@rowNum := 0)) b            WHERE
                    t.production_number = 979   
                ORDER BY
                    t.pub_time ASC
            ) table1    INNER JOIN(        SELECT
                t.auto_code ,
                t.id ,
                t.production_number ,
                t.pub_time ,
                (@a :=@a + 1) AS rowNo        FROM
                t_chapter t ,
                (SELECT(@a := 0)) b        WHERE
                t.production_number = 979
            ORDER BY
                t.pub_time ASC
        ) table2 ON table1.rowNo + 1 = table2.rowNo 
        WHERE
            timestampdiff(DAY , table2.pub_time , table1.pub_time) > 3;
    Salin selepas log masuk
    Salin selepas log masuk

    如果查询count>0则作品编号为979的作品存在断更,更多条件可以依据自己业务而定

    说明:

    这里用到了@,最开始我也不知道这是什么东西,然后我搜索mysql行号查到使用自定义变量(mysql特性)进行排序显示

    参考博客:

    SQL Server查询行号
    MYSQL rownum 实现
    MYSQL 自定义变量使用(推荐)

    • 需求

      1. 需要查询小说是否有断更,小说章节信息表中有发布时间:pub_time,如果发布时间间隔超过三天就算断更

    • 思路

      1. 查询小说章节信息表,将章节信息按照发布时间排序,加上行号。生成table1 和table2 信息一样

      2. left join 关联查询,table1行号为 n 与 table2行号为n+1的数据发布时间比较,如果存在大于三天则说明断更

    • 准备工作

    章节表:

    CREATE TABLE `t_chapter` (  `id` varchar(255) NOT NULL COMMENT '主键',  `auto_code` varchar(255) NOT NULL COMMENT '编号',  `production_number` varchar(11) NOT NULL COMMENT '作品编号',  `pub_time` datetime DEFAULT NULL COMMENT '发布时间',  PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8
    Salin selepas log masuk
    Salin selepas log masuk
    • 开始

      1. 对章节表根据发布时间升序排序并显示行号

            SELECT
                t.auto_code ,
                t.id ,
                t.production_number ,
                t.pub_time ,
                (@rowNum :=@rowNum + 1) AS rowNo        FROM
                t_chapter t ,
                (SELECT(@rowNum := 0)) b        WHERE 
               t.production_number = 1414(指定作品)        ORDER BY
                t.pub_time ASC
    Salin selepas log masuk
    Salin selepas log masuk

    查询结果已经按照发布时间排序
    c.png

    • 关联查询

        SELECT
            count(1)    FROM
            (            SELECT
                    t.auto_code ,
                    t.id ,
                    t.production_number ,
                    t.pub_time ,
                    (@rowNum :=@rowNum + 1) AS rowNo            FROM
                    t_chapter t ,
                    (SELECT(@rowNum := 0)) b            WHERE
                    t.production_number = 979   
                ORDER BY
                    t.pub_time ASC
            ) table1    INNER JOIN(        SELECT
                t.auto_code ,
                t.id ,
                t.production_number ,
                t.pub_time ,
                (@a :=@a + 1) AS rowNo        FROM
                t_chapter t ,
                (SELECT(@a := 0)) b        WHERE
                t.production_number = 979
            ORDER BY
                t.pub_time ASC
        ) table2 ON table1.rowNo + 1 = table2.rowNo 
        WHERE
            timestampdiff(DAY , table2.pub_time , table1.pub_time) > 3;
    Salin selepas log masuk
    Salin selepas log masuk

    如果查询count>0则作品编号为979的作品存在断更,更多条件可以依据自己业务而定

    说明:

    这里用到了@,最开始我也不知道这是什么东西,然后我搜索mysql行号查到使用自定义变量(mysql特性)进行排序显示

    相关文章:

    c语言中冒泡排序、插入排序、选择排序算法比较

    插入排序 排序算法学习-插入排序

    相关视频:

    数据库mysql视频教程

    Atas ialah kandungan terperinci MYSQL显示行号排序、同张表数据排序上下进行比较. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Kenyataan Laman Web ini
    Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
    Tutorial Popular
    Lagi>
    Muat turun terkini
    Lagi>
    kesan web
    Kod sumber laman web
    Bahan laman web
    Templat hujung hadapan