添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

SQL汇总统计与GROUP BY过滤查询实现

作者:黑码哥

这篇文章主要介绍了SQL汇总统计与GROUP BY过滤查询实现,GROUP BY 实质是先排序后分组,遵照索引建的最佳左前缀。当无法使用索引时,增大max_length_for_sort_data和sort_buffer参数的值

1、汇总统计

介绍几个聚集函数

有多少名学生

SELECT COUNT(*) FROM student;

SELECT COUNT(1) FROM student;

SELECT COUNT(score) FROM student;

所有学生的成绩总和

SELECT SUM(score) FROM student;

所有学生成绩的最高分

SELECT MAX(score) FROM student;

所有学生成绩最低分

SELECT MIN(score) FROM student;

所有学生成绩平均分

SELECT AVG(score) FROM student;

2、GROUT BY

如何获取每个班级的数学成绩平均分(因为学生太多,这里先不计算

成绩在80分以下的学生),以便比较不同班级的成绩?

SELECT class_id, AVG(score)
FROM student 
WHERE score > 80
GROUP BY class_id

汇总原理如下:

如何统计不同的交易所的总的买入金额?

SELECT LEFT(stock_code,2), SUM(price * volume)
FROM t_stock_trans_dtl
WHERE opt_typ = '买入'
GROUP BY LEFT(stock_code,2)

如何统计不同的交易所的不同交易类型的总的交易金额?

SELECT LEFT(stock_code,2), opt_typ, SUM(price * volume)
FROM t_stock_trans_dtl
GROUP BY LEFT(stock_code,2), opt_typ

SELECT里除了使用聚集函数返回的字段外,其他所有的字段都必须原样出现在GROUP BY的 后面;

GROUP BY会将NULL值的行,分到同一组计算统计值:

SELECT teacher_id, COUNT(*)
FROM student
GROUP BY teacher_id

3、如何对分组统计的结果进行过滤

GROUP BY + HAVING

如何获取教授15名以上学名的老师?

使用关键字:GROUP BY + HAVING

SELECT teacher_id, COUNT(*)
FROM student
GROUP BY teacher_id
HAVING COUNT(*) > 15

如何获取数学成绩平均分在70分及以上的班级?

SELECT class_id, AVG(score)
FROM student
GROUP BY class_id
HAVING AVG(score) > 70;

如何获取每个班级的成绩平均分(不计算成绩在80分以下的学

生且过滤掉平均分在90分以下的班级),以便比较不同班级的成绩?

SELECT class_id, AVG(score)
FROM student
WHERE score > 80
GROUP BY class_id
HAVING AVG(score) > 90;

4、如何对分组统计的结果进行排序

GROUP BY + ORDER BY

如何获取每个班级的数学成绩平均分(不计算成绩在80分以下的学

生),然后以平均分从高到低排序?

SELECT class_id, AVG(score)
FROM student
WHERE score > 80
GROUP BY class_id
ORDER BY AVG(score) DESC

5、介绍SELECT语句中各个子句的书写顺序

如何获取每个班级的数学成绩平均分(不计算成绩在80分以下的学

生且过滤掉平均分在90分以下的班级),然后以平均分从高到低排序?

SELECT class_id, AVG(score)
FROM student
WHERE score > 80
GROUP BY class_id
HAVING AVG(score) > 90
ORDER BY AVG(score) DESC

6、上方用到的表

到此这篇关于SQL汇总统计与GROUP BY过滤查询实现的文章就介绍到这了,更多相关SQL GROUP BY内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • SQL汇总统计与GROUP BY过滤查询实现
    SQL汇总统计与GROUP BY过滤查询实现
    2023-01-01
  • mysql数据库如何转移到oracle
    mysql数据库如何转移到oracle
    2022-12-12
  • MYSQL ON UPDATE CURRENT_TIMESTAMP当字段值发生改变时才会更新记录的时间
    MYSQL ON UPDATE CURRENT_TIMESTAMP当字段值发生改变时才会更
    2023-01-01
  • MySQL中超级有用的14个小知识总结
    MySQL中超级有用的14个小知识总结
    2022-12-12
  • SQL汇总统计与GROUP BY过滤查询实现
    SQL汇总统计与GROUP BY过滤查询实现
    2022-12-12
  • 浅谈MySQL查询出的值为NULL和N/A和空值的区别
    浅谈MySQL查询出的值为NULL和N/A和空值的区别
    2022-12-12
  • MYSQL ON UPDATE CURRENT_TIMESTAMP当字段值发生改变时才会更新记录的时间
    MYSQL ON UPDATE CURRENT
    2022-12-12
  • SQL更新与删除数据操作示例详解
    SQL更新与删除数据操作示例详解
    2022-12-12
  • 美国设下计谋,用娘炮文化重塑日本,已影响至中国
    美国设下计谋,用娘炮文化重塑日本,已影响至中国
    2021-11-19
  • 时空伴随者是什么意思?时空伴随者介绍
    时空伴随者是什么意思?时空伴随者介绍
    2021-11-09
  • 工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    2021-11-05
  • 2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2021-10-26
  • 电脑版 - 返回首页

    2006-2024 脚本之家 JB51.Net , All Rights Reserved.
    苏ICP备14036222号