前段时间面试的时候碰到这样一个面试题,因为很久没接触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的定义

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


————————————————
版权声明:本文为CSDN博主「爱java的训」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u010827070/article/details/79712303

sql查询成绩表中每一科成绩最高的分数以及这个学生的名字,学科名相关推荐

  1. mysql 学生成绩最高分的学科_sql查询成绩表中每一科成绩最高的分数以及这个学生的名字,学科名,面试的时候碰到的问题...

    前段时间面试的时候碰到这样一个面试题,因为很久没接触sql竟然没写出来. 如图有这样一张成绩表: 首先要理解group by 含义:"Group By"从字面意义上理解就是根据&q ...

  2. SQL查询成绩表中的每科第三名

    SQL查询成绩表中的每科第三名 题目要求 表格数据 grade表 c_id c_no c_name 1 1 80 1 2 90 1 3 70 1 4 95 2 1 64 2 2 88 2 3 89 2 ...

  3. Sql查询一个表中除了某个字段以外的所有字段的方法

    declare @name varchar(100) declare @sql varchar(1000)SET @sql='select ' DECLARE C11 CURSOR FORselect ...

  4. sql查询数据库表中重复数值

    sql查询数据库表中重复数值 -- 查询表中id重复的值 select id from 表名 group by id having count(*) > 1--查询表中的重复记录,重复记录是根据 ...

  5. SQL查询一个表中类别字段中Max()最大值对应的记录

    问题是: 数据库有一个表 code,里面有个点击量字段click_num和一个类别字段kind以及其它信息字段, 现在要搜出每个类别中点击量最大的那条记录,如果是10个类别,那么结果应该是10条记录, ...

  6. mysql查库存_如何用SQL查询Product表中库存最低的6种商品

    展开全部 使用代码:复 DELETE的语法是制: DELETEFROMtable_name. WHERE条件. DELETE后面不跟列名.2113 INSERT一般都用: INSERTINTOtabl ...

  7. SQL查询一个表中另外一个表不存在的数据

    #方法一:使用 not in ,容易理解,效率低  ~执行时间为:1.395秒~ SELECT COUNT(1) FROM ecs_goods WHERE ecs_goods.goods_id NOT ...

  8. sql查询教师表中比A部门最低工资高的所有老师

    使用自连接 使用自连接,from teachera, teacherb:然后设置筛选条件(b.dept='A' and a.sqlary>b.salary) select * from teac ...

  9. 1.查询Student表中的所有记录的Sname、Ssex和Class列(sql语句练习)

    sql语句练习题 此篇博文提供最基础的sql语句部分题目,答案仅供参考.交流可csdn私信或评论本人. 前期准备:数据库导入三张表TEACHER.STUDENT.SCORE. 调整格式:col 列名 ...

最新文章

  1. python list.pop 的方法的使用
  2. js关闭窗口无提示,不支持FF
  3. 如何快速判断某 URL 是否在 20 亿的网址 URL 集合中?
  4. iOS开发之APP内部切换语言
  5. python中lxml模块的使用
  6. 微软的面试题(超变态但是很经典)
  7. output怎么用_性能领先,即训即用,快速部署,飞桨首次揭秘服务器端推理库
  8. 盘点15个不起眼但非常强大的 Vim 命令
  9. windows下node安装
  10. Vue项目npm打包推荐方式
  11. 利用软碟通软件制作Ubuntu16.04系统启动盘
  12. hadoop如何解除safemode-安全模式
  13. VS2010 旗舰版序列号
  14. WIN7下安装WIN2003系统
  15. ORACLE账户提示EXPIRED(GRACE)问题解决
  16. win10搭建网络代理,供Linux使用
  17. 数据挖掘总结之消极学习与积极学习
  18. 简单的SWF视频播放器代码
  19. ROS2可视化利器---Foxglove Studio
  20. 前端接收list的情况 (批量添加)出现这个错说明不是传参错误,是解析错误

热门文章

  1. 霍兰德- 职业兴趣测评
  2. python框架Django数据库类型
  3. POE光纤收发器的三大应用场景
  4. Git基本命令的使用
  5. js字符串日期直接比较大小
  6. KSImageNamed 安装后无效解决方法
  7. Jenkins-API
  8. 【毕业设计_课程设计】基于机器学习的情感分类与分析算法设计与实现(源码+论文)
  9. BatchNorm和LayerNorm的比较
  10. KindEditor编辑器上传修改拿shell漏洞