码迷,mamicode.com
首页 > 数据库 > 详细

mysql 显示行号,以及分组排序

时间:2015-09-14 13:57:03      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:

建表:

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 

技术分享

mysql 显示行号,以及分组排序

标签:

原文地址:http://www.cnblogs.com/rhythmK/p/4806905.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!