`

MySQL group_concat()详解

 
阅读更多
  • 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)
分享到:
评论

相关推荐

    【GROUP_CONCAT】使用之MySQL官方文档翻译

    ### GROUP_CONCAT 函数详解 #### 一、概述 `GROUP_CONCAT` 是 MySQL 中一个非常实用的聚合函数,主要用于将来自同一分组的多个值连接成一个字符串。这一功能在许多场景下都非常有用,例如汇总数据、创建列表等。 ...

    MySQL拼接字符串函数GROUP_CONCAT详解

    MySQL中的GROUP_CONCAT函数是一个非常实用的聚合函数,主要用于在分组查询中将同一组内的多个值合并为一个字符串,通常用于数据汇总和报告。它能够处理非NULL值,并且可以进行排序、去重和自定义分隔符,极大地提高...

    Mysql的GROUP_CONCAT()函数使用方法

    ### MySQL的GROUP_CONCAT()函数使用详解 在MySQL中,`GROUP_CONCAT()`是一个非常实用且强大的聚合函数,主要用于将一组值连接成一个字符串。它常用于查询中,特别是需要将多个行的数据合并到一行时。本文将详细介绍...

    oracle合并列的函数wm_concat的使用详解

    最后,关于可能感兴趣的相关文章,包括Oracle中多行记录合并、连接、聚合字符串的不同方法,以及如何在Oracle中实现类似功能的其他技术,如使用`GROUP_CONCAT`(这是MySQL中的一个函数,Oracle没有直接对应的内置...

    详解MySQL中concat函数的用法(连接字符串)

    总结来说,MySQL中的`CONCAT`、`CONCAT_WS`和`GROUP_CONCAT`函数提供了强大的字符串处理能力,允许你灵活地连接和组合字符串,以满足不同的查询需求。在处理大量文本数据时,这些函数是数据库查询中不可或缺的一部分...

    lib_mysqludf_json-master.zip

    《MySQL UDF库函数与JSON格式转换详解》 在MySQL数据库管理系统中,有时我们需要将关系型数据转换为JSON格式,以便于数据交换、存储或处理。`lib_mysqludf_json`是一个用户定义的函数(User Defined Function, UDF...

    详解mysql中的concat相关函数

    总结,`CONCAT`、`CONCAT_WS`和`GROUP_CONCAT`都是MySQL中处理字符串连接的重要函数,它们在不同的场景下提供了灵活的数据组合方式。理解并熟练使用这些函数,可以提升你在数据库操作中的效率,特别是在处理复杂的...

    mysql字符串连接函数

    ### MySQL字符串连接函数详解 在处理数据库中的字符串操作时,MySQL提供了多种强大的工具来帮助我们进行数据处理。本文主要介绍几种常用的字符串连接函数,包括`CONCAT()`、`CONCAT_WS()`以及`GROUP_CONCAT()`函数...

    MySQL常用聚合函数详解

    一、AVG AVG(col) 返回指定列的平均值 二、COUNT COUNT(col) 返回指定列中非NULL值...GROUP_CONCAT([DISTINCT] expr [,expr …]  [ORDER BY {unsigned_integer | col_name | expr}  [ASC | DESC] [,col_name …]]  

    用Distinct在MySQL中查询多条不重复记录值,绝对的物有所值

    通过上述分析,我们了解到`DISTINCT`关键字在MySQL中的运用远不止去除简单重复值这么简单,它与`GROUP BY`、`COUNT`、`GROUP_CONCAT`等其他SQL功能结合,能够应对更为复杂的查询需求,极大地提升了数据处理的灵活性...

    mysql实现查询数据并根据条件更新到另一张表的方法示例

    4. **GROUP_CONCAT函数详解**: `GROUP_CONCAT`函数在MySQL中用于将同一组的某个列的值合并为一个字符串,用指定的分隔符(默认为逗号)分隔。它接受几个可选参数: - `DISTINCT`:去除重复的值。 - `ORDER BY`:...

    php手工注入.doc

    3. **使用`GROUP_CONCAT`和`LIMIT`**:为了快速获取所有表名,攻击者可以使用`GROUP_CONCAT`函数将多个表名合并为一个字符串,然后通过`CONCAT`函数在结果中插入分隔符。这比逐个尝试`LIMIT`更有效率。 4. **字段...

    linux上mysql5.7安装教程word版本

    - `group_concat_max_len = 4294967295`:增加GROUP_CONCAT函数返回的最大长度。 - `max_connections = 1000`:设置最大连接数。 - `table_open_cache = 6000`:缓存表的数量。 - `thread_cache_size = 50`:...

    MySQL多种递归查询方法.docx

    ### MySQL多种递归查询方法详解 #### 一、Oracle中的递归查询方法 在Oracle数据库中,递归查询可以通过`START WITH CONNECT BY PRIOR`语句实现。此语句允许用户按照树状结构来检索数据。 ##### 1. `START WITH ...

    E108-数据库安全-手工注入mysql数据库.pdf

    【知识点详解】 本文主要涉及的是数据库安全领域的一个经典问题——SQL注入攻击,特别是针对MySQL数据库的手工注入。SQL注入是一种常见的网络安全漏洞,攻击者通过在输入参数中嵌入恶意SQL语句,以获取、篡改或破坏...

    关于MySQL的sql_mode合理设置详解

    MySQL的`sql_mode`是数据库服务器的一个关键配置项,它定义了MySQL如何处理不符合标准SQL的行为,以及在数据验证和插入方面遵循何种规则。合理的设置`sql_mode`可以帮助确保数据的准确性,避免潜在的问题,特别是在...

    详解MySQL中的分组查询与连接查询语句

    分组查询 group by group by 属性名 [having 条件表达式][ with rollup] “属性名 ”指按照该字段值进行分组;...2)与group_concat()函数一起使用 每个分组中指定字段值都显示出来 实例: sel

    SQL注入手动盲注案例

    - **示例**:使用`union select 1,2,hex(group_concat(column_name)),4,5,6,7,8,9,10,11,12,13,14,15 from information_schema.columns where table_schema='news' and table_name='news_users'`,同样通过Hex编码...

Global site tag (gtag.js) - Google Analytics