mysql group by用法_mysql group by 语句使用总结

本文介绍了SQL中分组查询的基本语法及其多种实用技巧,包括使用group_concat()函数合并组内信息、统计记录总数、聚合函数的运用、having子句进行二次筛选及with rollup子句的应用等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,基本语法 其中显示得是一条记录

SELECT user_name,mobile_phone,`password` from users  GROUP BY is_status

2814add77270475cc424dec4fd5bc96a.png

2,Group by 语句中得group_concat()函数

如果想看组内所有得用户信息,就需要用到group_concat()函数 //合并组内信息

SELECT group_concat(user_name),group_concat(mobile_phone) from users GROUP BY is_status

4a16ecc1f95fd632872145a2451610be.png

3,统计记录总数 count()

SELECT count(*) totle, group_concat(user_name),group_concat(mobile_phone) from users GROUP BY is_status

2419193dcd1d797ee4304c5cb721f116.png

4,聚合

sum() 求和函数  max() 求最大值函数  min()求最小值函数   avg() 求平均值函数  。

SELECT sum(integral) num, group_concat(user_name),group_concat(email),

group_concat(is_forten) from users GROUP BY is_status

fa2e4b2fe208ae27d1ce8c3783d10b82.png

6,having子句:对分组结果进行二次筛选(where是第一次筛选)

SELECT sum(integral) num, group_concat(user_name),group_concat(email)  group_concat(is_forten) from users where is_forten=0     GROUP BY is_status HAVING num > 0

a5be3f03f4f8aa6f39f2604e0e0b8e90.png

6,with rollup 子句

可以实现在分组统计数据基础上在进行相同得统计(sum,avg ,count ....)

也就是说,当我们进行分组操作以后,又想在看总得信息,或者还有其他类似操作,普通group by 语句是不能实现得,就需要用到 有  with rollup 子句得group by 语句

SELECT coalesce(is_status,'总数'),sum(integral) num, group_concat(user_name),group_concat(email),

group_concat(is_forten) from users GROUP BY is_status with rollup

4926aa6745214aafae3efb27eec7eaca.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值