【Mysql】给查询记录增加序列号方法
创始人
2025-01-15 22:34:42
0

在MySQL 8.0版本中,你可以使用ROW_NUMBER()函数来添加序号。以下是一个示例查询,演示如何添加序号:

SELECT      ROW_NUMBER() OVER (ORDER BY column_name) AS serial_number,     column1, column2, ... FROM     your_table; 

请将column_name替换为你想要按照哪一列排序的列名。还可以添加其他需要的列,以在结果中显示它们。

这个查询将返回一个名为serial_number的新列,其中包含每行的序号。序号是根据ORDER BY子句中指定的列进行排序的。

需要注意的是,ROW_NUMBER()函数是在MySQL 8.0版本中引入的。在MySQL 5.7版本中,该函数不可用。如果你使用的是MySQL 5.7版本,并且需要添加序号,你可以考虑其他方法,例如使用变量或自增列。以下是一个使用变量的示例查询:

SELECT      @row_number:=@row_number + 1 AS serial_number,     column1, column2, ... FROM     your_table, (SELECT @row_number:=0) AS t ORDER BY column_name; 

在这个示例中,我们使用一个变量@row_number来追踪行号。通过将变量递增并与其他查询一起使用,你可以为每行添加一个序号。请记得将column_name替换为你想要按照哪一列排序的列名。

由于我安装的是MySQL 5.7版本的,下面用MySQL 5.7的演示一下:
查看版本号:

select version(); 

输出:
在这里插入图片描述
数据准备:

-- demo.schedule definition  CREATE TABLE `schedule` (   `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'id',   `start_time` datetime NOT NULL,   `end_time` datetime NOT NULL,   `employee_id` int(10) unsigned DEFAULT NULL,   PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=latin1; 

插入数据:

INSERT INTO demo.schedule (start_time, end_time, employee_id) VALUES('2023-09-08 07:50:00', '2023-09-08 12:00:00', 1); INSERT INTO demo.schedule (start_time, end_time, employee_id) VALUES('2023-09-08 12:40:00', '2023-09-08 17:20:00', 1); INSERT INTO demo.schedule (start_time, end_time, employee_id) VALUES('2023-09-08 18:10:00', '2023-09-08 20:30:00', 1);  

查询数据,给记录添加序列号:

SELECT      @row_number:=@row_number + 1 AS serial_number,     s.* FROM     schedule s, (SELECT @row_number:=0) AS t ORDER BY s.end_time ; 

输出结果:
在这里插入图片描述

相关内容

热门资讯

最新技巧“随意玩房卡辅助器透视... 最新技巧“随意玩房卡辅助器透视”太无语了透视辅助开挂详细教程-好像是有挂1、下载好随意玩房卡辅助器透...
一分钟揭秘“德扑之星怎么设置”... 一分钟揭秘“德扑之星怎么设置”外挂透明挂辅助神器(一贯是真的有挂)-哔哩哔哩;超受欢迎的德扑之星怎么...
透视工具“wepoker游戏下... 透视工具“wepoker游戏下载”详细透视辅助开挂细节揭秘-总是真的是有挂1.wepoker游戏下载...
黑科技插件!微扑克软件开发定制... 黑科技插件!微扑克软件开发定制app(透明黑科技)太坑了竟然是有挂(2021已更新)(哔哩哔哩)运微...
必备攻略“闲逸碰胡辅助软件”太... 必备攻略“闲逸碰胡辅助软件”太嚣张了透视辅助开挂细节方法-确实是真的有挂1、上手简单,内置详细流程视...
攻略讲解“德扑之星怎么让系统给... 攻略讲解“德扑之星怎么让系统给好牌”外挂透明挂辅助神器(一贯存在有挂)-哔哩哔哩;科技详细教程威信《...
透视科技“德普之星透视辅助软件... 透视科技“德普之星透视辅助软件”详细透视辅助开挂攻略教程-果然存在有挂;1、在德普之星透视辅助软件a...
黑科技了解!wepoke黑科技... 黑科技了解!wepoke黑科技功能(辅助挂)太实锤了真是有挂(2021已更新)(哔哩哔哩)1、wep...
分享一款“新佛手在线辅助软件”... 分享一款“新佛手在线辅助软件”太离谱了透视辅助开挂微扑克教程-原来存在有挂;1、很好的工具软件,可以...
发现一款“眯眯扑克怎么赢”外挂... 发现一款“眯眯扑克怎么赢”外挂透明挂辅助app(本然存在有挂)-哔哩哔哩;支持2-10人实时对战,虚...