ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 646|回复: 6

来自SQL里GROUP BY的几点应用求助

[复制链接]

TA的精华主题

TA的得分主题

发表于 2020-10-16 12:46 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
这里有一个表exma里面记录着考试成绩
1.png
通用SQL语句
  1. SELECT uid,AVG(mark)
  2. FROM exma
  3. GROUP BY uid;
复制代码
可以查询到汇总后的平均成绩:
2.png
现在我的疑问是除了几个例如SUM,AVG,MAX,MIN,COUNT之外的常用之外
比如我这里如果想改成查询每个人最后一次的成绩的话,SQL语句应该怎么写呢?

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-10-16 12:53 | 显示全部楼层
另外,通过表2
3.png
用SQL语句
  1. SELECT n.uid,name,sex,age,avg(mark)
  2. FROM name n,exma e
  3. WHERE n.uid=e.uid
  4. GROUP BY e.uid;
复制代码
可以让表2多了平均成绩一栏
4.png
但问题是,这张表里少了表2里原来有的“黑六”的信息记录
也就是虽然他没参加考试,但他的信息也应该被保留,他的成绩那栏可以为空,
代码又该怎么写呢?

TA的精华主题

TA的得分主题

发表于 2020-10-16 14:02 来自手机 | 显示全部楼层
水和米 发表于 2020-10-16 12:53
另外,通过表2

用SQL语句

left join 试试
SELECT name.uid,name,sex,age,avg(mark)
FROM name left join exam
on name.uid=exam.uid
GROUP BY e.uid;

另外一个取最后一次的成绩,我在sqlite里按时间排序后再group可以实现,你是啥数据库,可以试试,看看支不支持。

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-10-16 15:28 | 显示全部楼层
zpy2 发表于 2020-10-16 14:02
left join 试试
SELECT name.uid,name,sex,age,avg(mark)
FROM name left join exam

感谢老师,原来真的要靠左右链接才能实现数据筛选的结果,左右链接在我现在那本自学的书里还没有讲到,那我稍稍心安了,要不然好悲观哦,会对SQL有深深的恐惧感了

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-10-16 19:19 来自手机 | 显示全部楼层
水和米 发表于 2020-10-16 15:28
感谢老师,原来真的要靠左右链接才能实现数据筛选的结果,左右链接在我现在那本自学的书里还没有讲到,那 ...

with 排序 as (SELECT * FROM 最近成绩查询明细表 order by 姓名,日期) Select 姓名,成绩 FROM 排序 GROUP BY 姓名

Screenshot_2020-10-16-19-16-52.png
Screenshot_2020-10-16-19-15-57.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-10-16 19:34 | 显示全部楼层
123.png
源数据是左边的,希望得到的结果是右边带红字更正的

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-10-16 23:47 | 显示全部楼层
888.png
漫长一课,一点一点自己琢磨过来,感觉消化了好多的SQL的知识点~

评分

1

查看全部评分

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-4-26 22:01 , Processed in 0.039670 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表