|
网站内容均来自网络,本站只提供信息平台,如有侵权请联系删除,谢谢!
看了一些文章,终于知道该怎么在 mysql 里面实现 row_number() 排序
话不多说,show you the code:
第一步:建表:- create table grades(
- `name` varchar(10),
- `subject` varchar(10),
- `score` int(10)
- )
复制代码 第二步:写入数据- insert into grades(name, subject, score)
- values('小明', '语文', 85),
- ('小华', '语文', 89),
- ('小李', '语文', 91),
- ('小芳', '语文', 93),
- ('小明', '数学', 77),
- ('小华', '数学', 95),
- ('小李', '数学', 83),
- ('小芳', '数学', 88),
- ('小明', '英语', 90),
- ('小华', '英语', 92),
- ('小李', '英语', 85),
- ('小芳', '英语', 88)
复制代码 数据如下:
第三步:
需求:找出各科目单科第二的同学
首先,先排序:- select name, subject, score
- from grades
- order by subject, score desc
复制代码 数据如下:
然后,每个科目按照分组排序- select (@i:=case when @subject_pre=t1.subject then @i+1 else 1 end) as rn,
- t1.*,
- (@subject_pre:=subject)
- from (
- select name, subject, score
- from grades
- order by subject, score desc
- ) t1,
- (select @i:=0, @subject_pre:='') as t2
- group by subject, score
- order by subject, score desc
复制代码
解释一下:
添加一个比较项 subject_pre, 记录前一个科目是什么。
再加上一个自增的序列,实现index+1的功能。
因为数据已经是有序的,如果指向的科目和存储的前一个科目相同,那么序号+1,否则的话,序号从1开始重新计算。
这样就实现了分组排序。
最后,把 rn=2 的数据取出来- select name, subject, score from(select (@i:=case when @subject_pre=t1.subject then @i+1 else 1 end) as rn,t1.name,t1.subject,t1.score,(@subject_pre:=subject) from (select name, subject, score
- from grades
- order by subject, score desc) t1, (select @i:=0, @subject_pre:='') as t2group by subject, scoreorder by subject, score desc) twhere rn=2
复制代码 最后结果如下:
这样就使用mysql实现了row_number()的功能。
在网上找的资料,很多没写清楚,这里特地用一个示例把这个实现讲清楚了,希望对你有帮助!
到此这篇关于mysql使用自定义序列实现row_number功能的文章就介绍到这了,更多相关mysql row_number功能内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
x
免责声明
1. 本论坛所提供的信息均来自网络,本网站只提供平台服务,所有账号发表的言论与本网站无关。
2. 其他单位或个人在使用、转载或引用本文时,必须事先获得该帖子作者和本人的同意。
3. 本帖部分内容转载自其他媒体,但并不代表本人赞同其观点和对其真实性负责。
4. 如有侵权,请立即联系,本网站将及时删除相关内容。
|