sql查询成绩表中每一科成绩最高的分数以及这个学生的名字,学科名 |
您所在的位置:网站首页 › sql查询分数表最高分是多少 › sql查询成绩表中每一科成绩最高的分数以及这个学生的名字,学科名 |
这段时间在复习sql,看见一个博文讲的挺清楚,于是发挥了下拿来主义,只做复习只用。 如图有这样一张成绩表: 先来看这样一条sql语句:select subject,max(score) from grade GROUP BY subject 结果是:
注意:因为在select指定的字段要么就要包含在Group By语句的后面,作为分组的依据;要么就要被包含在聚合函数中。 所以这样是错误的。 group by语句中select指定的字段必须是“分组依据字段”,其他字段若想出现在select中则必须包含在聚合函数中,常见的聚合函数如下表: 这里提供几种方法: 我们已经通过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的定义 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 得出的结果是: 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 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |