首页 > 数据库技术 > 详细

SQL,如何查询成绩连续3次上升的同学?

时间:2018-10-16 17:01:09      阅读:267      评论:0      收藏:0      [点我收藏+]


-- 1.连续3次成绩上升
with t as
(select id,
StudentName,
Score,
row_number() over(partition by StudentName order by id desc) ‘rn‘
from #t)
select distinct a.id,a.StudentName
from t a
inner join t b on a.StudentName=b.StudentName
inner join t c on a.StudentName=c.StudentName
where a.rn=1 and b.rn=2 and c.rn=3
and a.Score>b.Score and b.Score>c.Score

/*
id StudentName
----------- -----------
34 李同学
38 王同学

(2 row(s) affected)
*/


-- 2.连续3次成绩下降
with t as
(select id,
StudentName,
Score,
row_number() over(partition by StudentName order by id desc) ‘rn‘
from #t)
select distinct a.id,a.StudentName
from t a
inner join t b on a.StudentName=b.StudentName
inner join t c on a.StudentName=c.StudentName
where a.rn=1 and b.rn=2 and c.rn=3
and a.Score<b.Score and b.Score<c.Score

/*
id StudentName
----------- -----------
35 赵同学

(1 row(s) affected)
*/

摘自CSDN问答,问答网址:https://bbs.csdn.net/topics/391059033

 

SQL,如何查询成绩连续3次上升的同学?

原文:https://www.cnblogs.com/lumingprince/p/9798740.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!