当前位置: 首页 > news >正文

MySQL语法分类 DQL(5)分组查询

为了更好的学习这里给出基本表数据用于查询操作
create table student (id int, name varchar(20), age int, sex varchar(5),address varchar(100),math int,english int 
);insert into student
(id,name,age,sex,address,math,english)
values 
(1,'马云',55,'男','杭州',66,78),
(2,'马化腾',45,'女','深圳',98,87),
(3,'马景涛',55,'男','香港',56,77),
(4,'柳岩',20,'女','湖南',76,65),
(5,'柳青',20,'男','湖南',86,NULL),
(6,'刘德华',57,'男','香港',99,99),
(7,'玛德',22,'女','香港',99,99),
(8,'德玛西亚',18,'男','南京',56,65)
;

分组查询 : 统计具有某个相同特征的一组数据

语法
group by 分组字段;
按照性别,分别查询男女同学的各科平均分、总人数(group)
//分组之后展示的字段有两类: 分组字段或聚合函数,其他字段没有意义
select sex, avg(math) as 数学平均分,avg(english) as 英语平均分,count(id) as 总人数 from student group by sex;

在这里插入图片描述

按照性别,分别查询男女同学的各科平均分、总人数,且限定分数低于70分的人不参与分组查询(group+where)
select sex, avg(math) as 数学平均分,avg(english) as 英语平均分,count(id) as 总人数 from student where math>70 group by sex;

在这里插入图片描述

按照性别,分别查询男女同学的各科平均分、总人数,且限定分数低于70分的人不参与分组查询,且分组后人数大于2人(group+where+having)
//常规写法
select sex, avg(math) as 数学平均分,avg(english) as 英语平均分,count(id) as 总人数 from student where math>70 group by sex having count(id)>2;
//别名写法
select sex, avg(math) as 数学平均分,avg(english) as 英语平均分,count(id) as 总人数 from student where math>70 group by sex having 总人数>2;

在这里插入图片描述

总结
where 在分组之前进行限定,如果条件不满足,则不参与分组,(后面不可以跟聚合函数)
having 在分组之后进行限定,如果条件不满足,则不会被查询出来,(后面可以跟聚合函数)
http://www.lryc.cn/news/319216.html

相关文章:

  • C++程序设计-练手题集合【期末复习|考研复习】
  • 文件上传漏洞------一句话木马原理解析
  • Openfeign使用教程(带你快速体验Openfeign的便捷)
  • 【leetcode】相同的树➕对称二叉树➕另一棵树的子树
  • uni-app 安卓手机判断是否开启相机相册权限
  • GPT实战系列-LangChain构建自定义Agent
  • uniapp-vue3 项目初始化集成配置【开箱即用】
  • 【Qt】使用Qt实现Web服务器(一):QtWebApp介绍、演示
  • SQLiteC/C++接口详细介绍之sqlite3类(八)
  • 面视题之——悲观锁和乐观锁
  • OpenAI 的 GPTs 提示词泄露攻击与防护实战:攻击卷(一)
  • 【 c 语言 】指针入门
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Swiper)
  • Python 导入Excel三维坐标数据 生成三维曲面地形图(面) 4-2、线条平滑曲面(原始颜色)但不去除无效点
  • win10 + cpu + pycharm + mindspore
  • 设计一个生产制造系统100问?
  • LeetCode 面试经典150题 26.删除有序数组中的重复项
  • 海豚调度系列之:集群部署(Cluster)
  • 居民健康监测小程序|基于微信小程序的居民健康监测小程序设计与实现(源码+数据库+文档)
  • 【海贼王的数据航海】排序——概念|直接插入排序|希尔排序
  • Docker环境快速搭建RocketMq
  • 【leetcode热题】比较版本号
  • 【ArcGISPro】道路数据下载并使用
  • DataGrip 面试题及答案整理,最新面试题
  • 2、设计模式之单例模式详解(Singleton)
  • 【django framework】ModelSerializer+GenericAPIView,如何在提交前修改某些字段值
  • 2024年【P气瓶充装】模拟考试及P气瓶充装证考试
  • <JavaEE> 数据链路层 -- 以太网协议、MTU限制、ARP协议
  • 认识Testbench仿真激励
  • Postman请求API接口测试步骤和说明