千家信息网

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

发表于:2025-11-06 作者:千家信息网编辑
千家信息网最后更新 2025年11月06日,小编给大家分享一下MYSQL显示行号排序、同张表数据排序上下进行比较的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧
千家信息网最后更新 2025年11月06日MYSQL显示行号排序、同张表数据排序上下进行比较的示例分析

小编给大家分享一下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
  • 开始

    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

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

  • 关联查询

    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;

如果查询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
  • 开始

    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

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

  • 关联查询

    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;

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

说明:

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

以上是"MYSQL显示行号排序、同张表数据排序上下进行比较的示例分析"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

时间 行号 查询 排序 章节 作品 信息 小说 数据 关联 变量 更多 篇文章 上下 示例 分析 业务 东西 内容 升序 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 winform从数据库获取日期 长宁区项目数据库服务价格查询 恋爱交友软件开发所需资金 gprs 数据服务器 盐城软件开发招聘 陵园设计软件开发 网络安全威胁实时地图怎么看 手机怎么与服务器建立安全连接 imap服务器怎么开启 道峰互联网科技 安全数据库的要求 怎样将电脑主机设置为服务器 浏览器与服务器建立连接的方式 海淀区信息化软件开发供应 地图导航类软件开发 大学数据库开发项目 上海蓝宇网络技术有限公司 我的世界国际服务器地址大全 爬虫如何开发数据库 软件开发营业执照个体户 软件开发学费一般多少 sql服务器名称什么时候有ip 网络技术计算机四级考试题型 58同城服务器连接超时 全球顶尖的网络安全实验室 客服平台的软件开发 proc数据库虚拟机安装 第6届互联网大会黑科技介绍 哇嘎画时代更新不了服务器列表 软件开发营业执照个体户
0