sql查询成绩表中每⼀科成绩最⾼的分数以及这个学⽣的名字,学科名,⾯试的时候碰到的问题
如图有这样⼀张成绩表:
⾸先要理解group by 含义:“Group By”从字⾯意义上理解就是根据“By”指定的规则对数据进⾏分组,所谓的分组就是将⼀个“数据集”划分成若⼲个“⼩区域”,然后针对若⼲个“⼩区域”进⾏数据处理。
先来看这样⼀条sql语句:select  subject,max(score) from grade GROUP BY subject
结果是:
这样正确的得出了每⼀科的最⾼分以及科⽬的名称。那是不是再在后⾯加个name就可以得出对应的学⽣的名字呢?我们可以试试:select  subject,max(score),name from grade GROUP BY subject
⼀看有结果以为成功了,但是对⽐数据后发现是错的,学⽣姓名和分数没对应上。如果你认为是成功的是因为对group by理解的不够,我也不知道这样查询为什么能出来结果,我使⽤的mysql数据库,如果是oracle的话就会报错。
注意:因为在select指定的字段要么就要包含在Group By语句的后⾯,作为分组的依据;要么就要被包含在聚合函数中。
所以这样是错误的。
group by语句中select指定的字段必须是“分组依据字段”,其他字段若想出现在select中则必须包含在聚合函数中,常见的聚合函数如下表:
函数作⽤⽀持性
sum(列名)求和
max(列名)最⼤值
min(列名)最⼩值
avg(列名)平均值
first(列名)第⼀条记录仅Access⽀持
last(列名)最后⼀条记录仅Access⽀持
count(列名)统计记录数注意和count(*)的区别
我们还是分析要求,通过要求来写sql语句。
这⾥提供⼏种⽅法:
我们已经通过group by分组来获得每⼀科的最⾼分以及科⽬名称,把它作为第⼀句sql,,然后再查询⼀下score表,到学科和分数都相同的记录:(⼦sql语句作为主sql语句的⼀部分)
#a.* 表⽰a表中所有的字段,b.*表⽰b表中所有的字段
select b.* from (select subject,max(score) m from grade GROUP BY subject) t,grade b where t.subject=b.subject and
t.m=b.score
结果如下:
对⽐发现数据是对的。
拓展问法:⽤⼀句SQL查出所有课程成绩最⾼和最低的学⽣及其分数。
⾸先,通过分组获得每个学科的最⾼分以及最低分:
select  subject,max(score),MIN(score) from grade GROUP BY subject
结果如下:
那我们如何把最⾼分对应的学⽣名字和最低分对应的名字放⼊呢,⽽且要求的数据展⽰是最⾼分⼀⾏,最低分⼀⾏。所以这样⾏不通。
通过上⾯的第⼀个问题得出的思路:
select b.* from (select subject,max(score) m from grade GROUP BY subject) t,grade b where t.subject=b.subject and
t.m=b.score
这样既然能得到每个学科的最⾼分,学⽣名字,学科名,那同样把max(score)改成min(score)不就可以获得最低分,学⽣名字,学科名字了吗?现在重点是如何把两条sql语句查询出来的结果整合到⼀起。
select b.* from (select subject,min(score) m from grade GROUP BY subject) t,grade b where t.subject=b.subject and
t.m=b.score
此时想到了sql的关键字 :    UNION的定义sql中union多表合并
UNION 操作符⽤于合并两个或多个 SELECT 语句的结果集。
请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。注释:默认地,UNION 操作符选取不同的值。如果
允许重复的值,请使⽤ UNION ALL。另外,UNION 结果集中的列名总是等于UNION 中第⼀个 SELECT 语句中的列名。
所以得出的sql是这样的:
select b.* from (select subject,max(score) m from grade GROUP BY subject) t,grade b where t.subject=b.subject and
t.m=b.score UNION
select b.* from (select subject,min(score) m from grade GROUP BY subject) t,grade b where t.subject=b.subject and
t.m=b.score
得出的结果是:
这样就ok了。如果还想添加⼀些东西。例如添加⼀列说明这个分数是最低分或者最⾼分。
select b.*,"最⾼分" from (select subject,max(score) m from grade GROUP BY subject) t,grade b where t.subject=b.subject and t.m=b.score
UNION
select b.*,"最低分" from (select subject,min(score) m from grade GROUP BY subject) t,grade b where t.subject=b.subject and t.m=b.score

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。