MySQL,分组order by

一、创建分组

sql 复制代码
## 创建分组
-- 返回每个发布会的参会人数
SELECT event_id,COUNT(*) as canjia_num FROM sign_guest GROUP BY event_id;

1、group by子句可以包含任意个列,但是但指定的所有列都是一起计算的。
group by 后2个字段一起计算的

2、group by后面可以跟:

a、检索列(字段名)

b、有效的表达式,但不能是聚集函数(如:sum()、avg()、min()、max()、count()等)

3、如果select中使用表达式,则group by中也必须使用相同的表达式(不能使用别名)。

4、除了聚集函数外,select中的所有字段,都要在group by中给出。

5、如果分组的列值有NULL,则会将所有NULL分为一组。

二、过滤分组

有一个共识要记在心里,即:

1、where过滤行,having过滤分组;

2、先过滤行,再过滤分组。

sql 复制代码
## 过滤分组

-- 参会人数大于3的发布会
SELECT event_id,COUNT(*) as canjia_num FROM sign_guest GROUP BY event_id
		HAVING canjia_num >3;

-- 还有哪些嘉宾没签到
SELECT event_id FROM sign_guest WHERE sign=0
		GROUP BY event_id;

-- 未签到嘉宾大于2的发布会
-- 拆解:
-- 		a、过滤行,过滤出未签到的嘉宾 --> 过滤行:where sing=0的数据
--      b、分组,每个发布会:group by event_id --> 计总数(每个发布会未签到的嘉宾总数):select子句count()
-- 		c、过滤分组 --> canjia_num>2
		
SELECT event_id,COUNT(*) as canjia_num FROM sign_guest WHERE sign=0
		GROUP BY event_id
		HAVING canjia_num>2;


# 与上一条相同,追加了排序
SELECT event_id,COUNT(*) as canjia_num FROM sign_guest WHERE sign=0
		GROUP BY event_id
		HAVING canjia_num>2
		ORDER BY canjia_num DESC;

Select子句顺序:

1、select --> from 已是共识

2、where 行过滤

3、group by 分组

4、having 分组过滤

5、order by 排序

6、limit 限制检索行数

类似题:有2个订单以上,且订单>=10元的产品供应商

相关推荐
Q_9709563915 分钟前
java+vue+SpringBoo校园失物招领网站(程序+数据库+报告+部署教程+答辩指导)
java·数据库·vue.js
Wyc7240923 分钟前
Maven
java·数据库·maven
程序猿小D26 分钟前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的电影小说网站管理系统,推荐!
java·数据库·mysql·spring·毕业设计·ssm框架·电影小说网站
羊小猪~~31 分钟前
数据库学习笔记(十七)--触发器的使用
数据库·人工智能·后端·sql·深度学习·mysql·考研
背太阳的牧羊人1 小时前
Neo4j 的向量搜索(Neo4jVector)和常见的向量数据库(比如 Milvus、Qdrant)之间的区别与联系
数据库·neo4j·milvus
liulun1 小时前
在浏览器中使用SQLite(官方sqlite3.wasm)
数据库·sqlite·wasm
叁沐2 小时前
MySQL 05 深入浅出索引(下)
mysql
陈卓4102 小时前
MySQL-主从复制&分库分表
android·mysql·adb
IT项目管理3 小时前
达梦数据库DMHS介绍及安装部署
linux·数据库
你都会上树?3 小时前
MySQL MVCC 详解
数据库·mysql