当前位置:网站首页>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开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
- app逆向1某联
- 分布式计算实验4 随机信号分析系统
- Distributed Computing Experiment 2 Thread Pool
- Error EPERM operation not permitted, mkdir ‘Dsoftwarenodejsnode_cache_cacach两种解决办法
- 10个程序员可以接私活的平台和一些建议,赚麻...
- CSDN21天学习挑战赛——day1 正则表达式大总结
- Praat:语音标注工具【保存为TextGrid文件】
- MySQL配置文件配置
- 花了近70美元入手的学生版MATLAB体验到底如何?
- 小猫爪:AWR294x学习笔记02-AWR294x之DPM&IPC
猜你喜欢
随机推荐
JVM工具之 JPS
Provide 和 Inject 的用法
New Questions in Module B of Secondary Vocational Network Security Competition
七夕情人节:中英文祝福短信送给你
SQL如何从字符串截取指定字符(LEFT、MID、RIGHT三大函数)
反射与枚举
如何用matlab做高精度计算?【第三辑】(完)
花了近70美元入手的学生版MATLAB体验到底如何?
Error occurred while trying to proxy request项目突然起不来了
海康VisionMaster与西门子Smart 200进行S7通信
Verilog“七宗罪”
无人驾驶运用了什么技术,无人驾驶技术是
NelSon:一款新的适配matlab编程语法的编程工具
窥探晶体世界的奥秘 —— 230种空间群晶体结构模型全在这里
MySQL面试题大全(陆续更新)
LAN技术-3iStack
函数柯里化详解
一天搞定JDBC01:连接数据库并执行sql语句
【学习笔记】AGC036
Mac安装PHP开发环境









