MySQL如何给查询结果添加行号
更新时间:2024年07月27日 10:23:04 作者:BestTomDoG
这篇文章主要介绍了MySQL如何给查询结果添加行号的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
MySQL给查询结果添加行号
SET @rownum:=0; -- 注意:“:=”表示赋值,“=”表示比较,“@”表示变量 SELECT provinces.*,@rownum:=@rownum+1 as rownum FROM provinces;
SELECT provinces.*,@rownum:=@rownum+1 as rownum FROM provinces,(SELECT @rownum:=0) a;
-- MySQL8.0以上版本支持函数,和oracle数据库语法一样 SELECT provinces.*,row_number() over(ORDER BY id) as rownum FROM provinces;
结果集

MySQL显示行号,以及分组排序
建表
CREATE TABLE `my_tb` ( `id` int(11) NOT NULL AUTO_INCREMENT, `parent_code` varchar(255) DEFAULT NULL, `code` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;
初始数据
INSERT INTO `my_tb` ( `parent_code`, `code`) VALUES ('01', '001');
INSERT INTO `my_tb` ( `parent_code`, `code`) VALUES ('01', '002');
INSERT INTO `my_tb` ( `parent_code`, `code`) VALUES ('02', '001');
INSERT INTO `my_tb` ( `parent_code`, `code`) VALUES ('01', '003');
INSERT INTO `my_tb` ( `parent_code`, `code`) VALUES ('02', '002');
INSERT INTO `my_tb` ( `parent_code`, `code`) VALUES ('03', '001');
INSERT INTO `my_tb` ( `parent_code`, `code`) VALUES ('04', '001');查询行号
-- 生成 行号 select @r:=@r+1 as row_num , a.* from my_tb a ,(select @r:=0) b

显示分组号
-- 生成 分组排序号
select
@group_row:=CASE when @parent_code=a.parent_code then @group_row+1 else 1 end as groupRow,
@parent_code:=a.parent_code as parent_code,
a.code
from my_tb a ,( select @group_row:=1, @parent_code:='') as b
ORDER BY a.parent_code , a.code 
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Ubuntu查看修改mysql的登录名和密码、安装phpmyadmin
这篇文章主要介绍了Ubuntu查看修改mysql的登录名和密码、安装phpmyadmin,本文分步骤给大家讲解的非常详细,需要的朋友可以参考下2019-11-11
MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引详细介绍
本文主要介绍了MySQL的索引类型,根据索引的存储方式来划分,索引可以分为聚簇索引和非聚簇索引。聚簇索引的特点是叶子节点包含了完整的记录行,而非聚簇索引的叶子节点只有所以字段和主键ID,感兴趣的同学可以阅读本文2023-04-04


最新评论