当前位置:网站首页>MySQL group_concat()详解
MySQL group_concat()详解
2022-08-04 06:41:00 【m0_61083409】
GROUP_CONCAT(xxx):是将分组中括号里对应的字符串进行连接.如果分组中括号里的参数xxx有多行,那么就会将这多行的字符串连接,每个字符串之间会有特定的符号进行分隔。
对应的语法格式将分组中column1这一列对应的多行的值按照column2 升序或者降序进行连接,其中分隔符为seq
如果用到了DISTINCT,将表示将不重复的column1按照column2升序或者降序连接
如果没有指定SEPARATOR的话,也就是说没有写,那么就会默认以 ','分隔
GROUP_CONCAT([DISTINCT] column1 [ORDER BY column2 ASCDESC] [SEPARATOR seq]);
[ ORDER BY column2 ASCDESC] :表示将会根据column2升序或者降序连接.其中column2不一定一定要求是column1,只要保证column2在这个分组中即可.如果没有写ORDER BY句段,那么连接是没有顺序的。
[ SEPARATOR seq] : 表示各个column1将会以什么分隔符进行分隔,例如SEPARATOR '_’,则表示column1将会以_进行分隔。如果没有指定seq的时候,也即没有写SEPARATOR seq这个句段,那么就会默认是以,
分隔的。
CONCAT函数中要连接的数据含有NULL,最后返回的是NULL,但是GROUP_CONCAT不会这样,他会忽略NULL值。
mysql> SELECT * FROM employee2;
+----+-----------+------+---------+---------+
| id | name | age | salary | dept_id |
+----+-----------+------+---------+---------+
| 3 | 小肖 | 29 | 30000.0 | 1 |
| 4 | 小东 | 30 | 40000.0 | 2 |
| 6 | 小非 | 24 | 23456.0 | 3 |
| 7 | 晓飞 | 30 | 15000.0 | 4 |
| 8 | 小林 | 23 | 24000.0 | NULL |
| 10 | 小五 | 20 | 4500.0 | NULL |
| 11 | 张山 | 24 | 40000.0 | 1 |
| 12 | 小肖 | 28 | 35000.0 | 2 |
| 13 | 李四 | 23 | 50000.0 | 1 |
| 17 | 王武 | 24 | 56000.0 | 2 |
| 18 | 猪小屁 | 2 | 56000.0 | 2 |
| 19 | 小玉 | 25 | 58000.0 | 1 |
| 21 | 小张 | 23 | 50000.0 | 1 |
| 22 | 小胡 | 25 | 25000.0 | 2 |
| 96 | 小肖 | 19 | 35000.0 | 1 |
| 97 | 小林 | 20 | 20000.0 | 2 |
+----+-----------+------+---------+---------+
16 rows in set (0.16 sec)
mysql> SELECT
-> dept_id,
-> GROUP_CONCAT(name ORDER BY age DESC SEPARATOR '*') -- 分组中的name中的多行数据将按照age降序进行连接,分隔符为 *
-> FROM employee2
-> GROUP BY dept_id; -- 注意如果这里没有GROUP BY dept_id,那么就会因为输出dept_id而发生报错
+---------+----------------------------------------------------+
| dept_id | GROUP_CONCAT(name ORDER BY age DESC SEPARATOR '*') |
+---------+----------------------------------------------------+
| NULL | 小林*小五 |
| 1 | 小肖*小玉*张山*小张*李四*小肖 |
| 2 | 小东*小肖*小胡*王武*小林*猪小屁 |
| 3 | 小非 |
| 4 | 晓飞 |
+---------+----------------------------------------------------+
mysql> SELECT
-> GROUP_CONCAT(name SEPARATOR '*')
-> FROM employee2; -- 这时候虽然没有使用GROUP BY,但是可以正常运行,此时是将所有的name连接,连接时为无序,分隔符为*
+-------------------------------------------------------------------------------------------------------+
| GROUP_CONCAT(name SEPARATOR '*') |
+--------------------------------------------------------------------------------------------------------
| 小肖*小东*小非*晓飞*小林*小五*张山*小肖*李四*王武*猪小屁*小玉*小张*小胡*小肖*小林 |
+-------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
mysql> SELECT
-> GROUP_CONCAT(DISTINCT name SEPARATOR '*') -- 将不同的name进行连接
-> FROM employee2;
+-----------------------------------------------------------------------------------------------+
| GROUP_CONCAT(DISTINCT name SEPARATOR '*') |
+-----------------------------------------------------------------------------------------------+
| 小东*小五*小张*小林*小玉*小肖*小胡*小非*张山*晓飞*李四*猪小屁*王武 |
+-----------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
mysql> SELECT
-> dept_id,
-> GROUP_CONCAT(name) AS employees
-> FROM employee2
-> GROUP BY dept_id; -- 输出每个部门的员工,每个员工之间用逗号分隔,因为没有写SEPARATOR ,所以就默认以逗号分隔
+---------+----------------------------------------------+
| dept_id | employees |
+---------+----------------------------------------------+
| NULL | 小林,小五 |
| 1 | 小肖,张山,李四,小玉,小张,小肖 |
| 2 | 小东,小肖,王武,猪小屁,小胡,小林 |
| 3 | 小非 |
| 4 | 晓飞 |
+---------+----------------------------------------------+
5 rows in set (0.00 sec)
mysql> SELECT
-> dept_id,
-> GROUP_CONCAT(DISTINCT name) -- 将不同的name连接,并且用逗号分隔
-> AS employees
-> FROM employee2
-> GROUP BY dept_id;
+---------+----------------------------------------------+
| dept_id | employees |
+---------+----------------------------------------------+
| NULL | 小五,小林 |
| 1 | 小张,小玉,小肖,张山,李四 |
| 2 | 小东,小林,小肖,小胡,猪小屁,王武 |
| 3 | 小非 |
| 4 | 晓飞 |
+---------+----------------------------------------------+
5 rows in set (0.00 sec)
所以利用GROUP_CONCAT,就可以解决按照dept_no进行汇总题目了.
值得一提的是,GROUP_CONCAT只是将xxx这一列中的多行数据进行连接成为一行字符串,而CONCAT则是可以将多列数据进行连接。所以当GROUP_CONCAT和(CONCAT_WS或者CONCAT)一起使用的时候,使得查询更加有效.例如下面的例子正是如此:
mysql> SELECT * FROM employee2;
+----+-----------+------+---------+---------+
| id | name | age | salary | dept_id |
+----+-----------+------+---------+---------+
| 3 | 小肖 | 29 | 30000.0 | 1 |
| 4 | 小东 | 30 | 40000.0 | 2 |
| 6 | 小非 | 24 | 23456.0 | 3 |
| 7 | 晓飞 | 30 | 15000.0 | 4 |
| 8 | 小林 | 23 | 24000.0 | NULL |
| 10 | 小五 | 20 | 4500.0 | NULL |
| 11 | 张山 | 24 | 40000.0 | 1 |
| 12 | 小肖 | 28 | 35000.0 | 2 |
| 13 | 李四 | 23 | 50000.0 | 1 |
| 17 | 王武 | 24 | 56000.0 | 2 |
| 18 | 猪小屁 | 2 | 56000.0 | 2 |
| 19 | 小玉 | 25 | 58000.0 | 1 |
| 21 | 小张 | 23 | 50000.0 | 1 |
| 22 | 小胡 | 25 | 25000.0 | 2 |
| 96 | 小肖 | 19 | 35000.0 | 1 |
| 97 | 小林 | 20 | 20000.0 | 2 |
+----+-----------+------+---------+---------+
16 rows in set (0.00 sec)
mysql> SELECT
-> dept_id,
-> GROUP_CONCAT(CONCAT(name,"(",salary,")") SEPARATOR ';') -- 将利用name(salary)进行连接,其中分隔符为';'
-> FROM
-> employee2
-> GROUP BY dept_id;
+---------+---------------------------------------------------------------------------------------------+
| dept_id | GROUP_CONCAT(CONCAT(name,"(",salary,")") SEPARATOR ';')
+---------+---------------------------------------------------------------------------------------------+
| NULL | 小林(24000.0);小五(4500.0)
| 1 | 小肖(30000.0);张山(40000.0);李四(50000.0);小玉(58000.0);小张(50000.0);小肖(35000.0)
| 2 | 小东(40000.0);小肖(35000.0);王武(56000.0);猪小屁(56000.0);小胡(25000.0);小林(20000.0)
| 3 | 小非(23456.0)
| 4 | 晓飞(15000.0)
+---------+---------------------------------------------------------------------------------------------+
5 rows in set (0.30 sec)
详细的可以看一下这篇文章:MySQL group_concat()
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
猜你喜欢
随机推荐
反序列化字符逃逸漏洞之
MySQL复制表结构、表数据的方法
MATLAB版量化交易技术分析工具TA-Lib【不付费也可获取,不要被付费吓跑】
Transform 相对位置变换,坐标系转换
MMDeploy部署实战系列【第三章】:MMdeploy pytorch模型转换onnx,tensorrt
中职网络安全竞赛B模块新题
串口监听 - 软件方案
海康VisionMaster与西门子Smart 200进行S7通信
【深度学习实践(二)】上手手写数字识别
Distributed Computing Experiment 2 Thread Pool
【愚公系列】2022年07月 Go教学课程 027-深拷贝和浅拷贝
分布式计算MapReduce | Spark实验
全国职业院校技能大赛网络安全竞赛之应急响应
53个全球免费学术资源数据库整理,查资料写论文必备【开学必备】
powershell和cmd对比
babylon 里面加gltf 模型
90多款matlab工具箱打包放送
SQL去重的三种方法汇总
idea使用@Autowired注解爆红原因及解决方法
Redis非关系型数据库