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

 更新时间:2023年01月05日 09:20:09   作者:黑码哥  
这篇文章主要介绍了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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL中的max()函数使用教程

    MySQL中的max()函数使用教程

    这篇文章主要介绍了MySQL中的max()函数使用教程,是学习MySQL入门的基础知识,需要的朋友可以参考下
    2015-05-05
  • CentOS6.8使用cmake安装MySQL5.7.18

    CentOS6.8使用cmake安装MySQL5.7.18

    这篇文章主要为大家详细介绍了CentOS6.8使用cmake安装MySQL5.7.18的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • MySQL 元数据锁及问题排查的解决

    MySQL 元数据锁及问题排查的解决

    MySQL中的元数据锁主要用于管理并发操作下的数据字典一致性,本文主要介绍了MySQL 元数据锁及问题排查的解决,具有一定的参考价值,感兴趣的可以了解一下
    2024-09-09
  • MySQL系列之二 多实例配置

    MySQL系列之二 多实例配置

    MySQL多实例就是在一台服务器上同时开启多个不同的服务端口,本文就介绍一下MySQL多实例配置,感兴趣的可以了解一下
    2021-07-07
  • mysql 触发器语法与应用示例

    mysql 触发器语法与应用示例

    这篇文章主要介绍了mysql 触发器语法与应用,结合实例形式详细分析了mysql 触发器的基本语法与插入、更细、删除等相关操作技巧,需要的朋友可以参考下
    2020-05-05
  • mysql 5.7 安装配置方法图文教程

    mysql 5.7 安装配置方法图文教程

    这篇文章主要为大家分享了mysql 5.7 安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • SQL HAVING子句在GROUP BY中的条件筛选灵活运用

    SQL HAVING子句在GROUP BY中的条件筛选灵活运用

    这篇文章主要为大家介绍了SQL HAVING子句在GROUP BY中的条件筛选灵活运用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • mysql limit分页优化方法分享

    mysql limit分页优化方法分享

    MySQL的优化是非常重要的。其他最常用也最需要优化的就是limit。MySQL的limit给分页带来了极大的方便,但数据量一大的时候,limit的性能就急剧下降。
    2011-04-04
  • MySQL字符集中文乱码解析

    MySQL字符集中文乱码解析

    这篇文章主要给大家解析了MySQL字符集中文乱码的问题,文章通过代码示例讲解的非常详细,对我们的学习或工作有一定的帮助,需要的朋友可以参考下
    2023-09-09
  • mysql 存在该记录则更新,不存在则插入记录的sql

    mysql 存在该记录则更新,不存在则插入记录的sql

    非常不错的功能,主要用于更新特定的记录,如果存在这条记录则更新一下,如果不存在则插入记录。应用于配置文件等。
    2010-04-04

最新评论