mysql分组显示行号_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');

f9b33e0d6a844b1586d3fdc364be7eae.png

查询行号:

-- 生成 行号

select @r:=@r+1 as row_num , a.* from my_tb a ,(select @r:=0) b

3940550895d8e5583e5e2c9ef7f3a6f9.png

显示分组号:

-- 生成 分组排序号

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值