`
- 浏览:
86538 次
- 性别:
- 来自:
上海
-
- https://blog.csdn.net/weixin_46544385/article/details/120563650
-
- GROUP_CONCAT(xxx):是将分组中括号里对应的字符串进行连接.如果分组中括号里的参数xxx有多行,那么就会将这多行的字符串连接,每个字符串之间会有特定的符号进行分隔。
对应的语法格式
- [ ORDER BY column2 ASC\DESC] :表示将会根据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> SELEC 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)
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
【GROUP_CONCAT】使用之MySQL官方文档翻译
作用: GROUP_CONCAT函数可以拼接某个字段值成字符串,默认的分隔符是 逗号,即...SHOW VARIABLES LIKE 'group_concat_max_len' 操作方法:(如图) 调整长度设置方法: (1)在MySQL配置文件中加入: 文件:my.ini
在mysql中,有个函数叫“group_concat”,平常使用可能发现不了问题,在处理大数据... 使用group_concat_max_len系统变量,你可以设置允许的最大长度。 系统默认的分隔符是逗号 修改方式: SET [SESSION | GLOBAL] g
主要介绍了mysql group_concat()函数用法,结合实例形式较为详细的group_concat()函数的功能、使用方法与相关注意事项,需要的朋友可以参考下
主要介绍了mysql group_concat实现把分组字段写成一行的方法,结合实例形式分析了group_concat函数的功能、查询用法及相关操作技巧,需要的朋友可以参考下
本文实例讲述了mysql中GROUP_CONCAT的使用方法。分享给大家供大家参考,具体如下: 现在有三个表,结构如下: cate表: CREATE TABLE `cate` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'id', `...
本文通过实例介绍了MySQL中的group_concat函数的使用方法,需要的朋友可以适当参考下
语法: GROUP_CONCAT([DISTINCT] expr [,expr …][ORDER BY {unsigned_integer | col_name | expr}[ASC | DESC] [,col_name …]][SEPARATOR str_val]) 下面演示一下这个函数,先建立一个学生选课表...
本文给大家详细讲解了MySQL的拼接字符串函数GROUP_CONCAT的几种使用方法以及详细示例,有需要的小伙伴可以参考下
MySQL中group_concat函数,完整的语法如下: 代码如下:group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator ‘分隔符’]) 基本查询 代码如下:select * from aa; 代码如下:+——+——+|...
主要介绍了MySQL统计函数GROUP_CONCAT使用中的陷阱,结合实例形式分析了GROUP_CONCAT用于统计时的长度限制问题与相关注意事项,需要的朋友可以参考下
Oracle新版中不支持 WM_CONCAT的处理方法,直接创建一个自定义函数代替
wmsys_wm_concat函数结果拆解/wmsys_wm_concat函数结果拆解/wmsys_wm_concat函数结果拆解/wmsys_wm_concat函数结果拆解/
group_concat()函数的参数是可以直接使用order by排序的。...以上这篇浅谈MySQL中group_concat()函数的排序方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持软件开发网。
ORA-00904 WMSYS.WM_CONCAT标识符无效解决方案