sql 查询各个班级的最高分和最低分,最高分与最低分为一列

如下:SQL:selectstudent,class,gradefromttstudentclassgrade------------------------------... 如下:

SQL:select student,class,grade from tt
student class grade
--------------------------------
A1 501 80
B1 501 70
C1 501 50
D1 501 90
A2 502 70
B2 502 60
C3 503 70
D3 503 80
A3 503 60
B3 503 90

要求查出的数据格式如下(最高分与最低分为一列,而不是2列)

student class grade

------------------------------------
C1 501 50
D1 501 90
B2 502 50
A2 502 70
A3 503 60
B3 503 90
展开
 我来答
frogley
2013-09-11 · TA获得超过1854个赞
知道小有建树答主
回答量:1008
采纳率:50%
帮助的人:1067万
展开全部
select student,class,grade from (
select *
,row_number() over (partition by class order by grade) seq1
,row_number() over (partition by class order by grade desc) seq2
from tt ) t
where seq1=1 or seq2=1

结果如下:

追问
这Sql写的牛逼,第一次见有人这样写,赞一个!还有木有其他写法?
追答

取最大最小的值的语句都可以用not exist来写:

select * from tt a 
where not exists ( select 1 from tt b 
  where b.class=a.class and b.grade<a.grade)
union all
select * from tt a 
where not exists ( select 1 from tt b 
  where b.class=a.class and b.grade>a.grade)
h821463015
2013-09-11 · TA获得超过723个赞
知道答主
回答量:108
采纳率:0%
帮助的人:46.8万
展开全部
select * from table where grade in(
select min(grade) from table group by class
union all
select max(grade) from table group by class)
order by class
追问
我肯定这样不行
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式