MySQL中函数CONCAT及GROUP_CONCAT

本文介绍MySQL中的CONCAT和GROUP_CONCAT函数用法,包括连接字符串、处理NULL值、指定分隔符以及对结果排序等特性。

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

MySQL中函数CONCAT及GROUP_CONCAT

Posted on  2012-09-03 16:36  Appleat 阅读( 77645) 评论( 0编辑  收藏

一、CONCAT()函数
CONCAT()函数用于将多个字符串连接成一个字符串。
使用数据表Info作为示例,其中SELECT id,name FROM info LIMIT 1;的返回结果为
+----+--------+
| id | name   |
+----+--------+
|  1 | BioCyc |
+----+--------+
1、语法及使用特点:
CONCAT(str1,str2,…)                       
返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。可以有一个或多个参数。

2、使用示例:
SELECT CONCAT(id, ‘,’, name) AS con FROM info LIMIT 1;返回结果为
+----------+
| con      |
+----------+
| 1,BioCyc |
+----------+

SELECT CONCAT(‘My’, NULL, ‘QL’);返回结果为
+--------------------------+
| CONCAT('My', NULL, 'QL') |
+--------------------------+
| NULL                     |
+--------------------------+

3、如何指定参数之间的分隔符
使用函数CONCAT_WS()。使用语法为:CONCAT_WS(separator,str1,str2,…)
CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。如果分隔符为 NULL,则结果为 NULL。函数会忽略任何分隔符参数后的 NULL 值。但是CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。

如SELECT CONCAT_WS('_',id,name) AS con_ws FROM info LIMIT 1;返回结果为
+----------+
| con_ws   |
+----------+
| 1_BioCyc |
+----------+

SELECT CONCAT_WS(',','First name',NULL,'Last Name');返回结果为
+----------------------------------------------+
| CONCAT_WS(',','First name',NULL,'Last Name') |
+----------------------------------------------+
| First name,Last Name                         |
+----------------------------------------------+

二、GROUP_CONCAT()函数
GROUP_CONCAT函数返回一个字符串结果,该结果由分组中的值连接组合而成。
使用表info作为示例,其中语句SELECT locus,id,journal FROM info WHERE locus IN('AB086827','AF040764');的返回结果为
+----------+----+--------------------------+
| locus    | id | journal                  |
+----------+----+--------------------------+
| AB086827 |  1 | Unpublished              |
| AB086827 |  2 | Submitted (20-JUN-2002)  |
| AF040764 | 23 | Unpublished              |
| AF040764 | 24 | Submitted (31-DEC-1997)  |
+----------+----+--------------------------+

1、使用语法及特点:
GROUP_CONCAT([DISTINCT] expr [,expr ...]
[ORDER BY {unsigned_integer | col_name | formula} [ASC | DESC] [,col ...]]
[SEPARATOR str_val])
在 MySQL 中,你可以得到表达式结合体的连结值。通过使用 DISTINCT 可以排除重复值。如果希望对结果中的值进行排序,可以使用 ORDER BY 子句。
SEPARATOR 是一个字符串值,它被用于插入到结果值中。缺省为一个逗号 (","),可以通过指定 SEPARATOR "" 完全地移除这个分隔符。
可以通过变量 group_concat_max_len 设置一个最大的长度。在运行时执行的句法如下: SET [SESSION | GLOBAL] group_concat_max_len = unsigned_integer;
如果最大长度被设置,结果值被剪切到这个最大长度。如果分组的字符过长,可以对系统参数进行设置:SET @@global.group_concat_max_len=40000;

2、使用示例:
语句 SELECT locus,GROUP_CONCAT(id) FROM info WHERE locus IN('AB086827','AF040764') GROUP BY locus; 的返回结果为
+----------+------------------+
| locus    | GROUP_CONCAT(id) |
+----------+------------------+
| AB086827 | 1,2              |
| AF040764 | 23,24            |
+----------+------------------+

语句 SELECT locus,GROUP_CONCAT(distinct id ORDER BY id DESC SEPARATOR '_') FROM info WHERE locus IN('AB086827','AF040764') GROUP BY locus;的返回结果为
+----------+----------------------------------------------------------+
| locus    | GROUP_CONCAT(distinct id ORDER BY id DESC SEPARATOR '_') |
+----------+----------------------------------------------------------+
| AB086827 | 2_1                                                      |
| AF040764 | 24_23                                                    |
+----------+----------------------------------------------------------+

语句SELECT locus,GROUP_CONCAT(concat_ws(', ',id,journal) ORDER BY id DESC SEPARATOR '. ') FROM info WHERE locus IN('AB086827','AF040764') GROUP BY locus;的返回结果为
+----------+--------------------------------------------------------------------------+
| locus    | GROUP_CONCAT(concat_ws(', ',id,journal) ORDER BY id DESC SEPARATOR '. ') |
+----------+--------------------------------------------------------------------------+
| AB086827 | 2, Submitted (20-JUN-2002). 1, Unpublished                               |
| AF040764 | 24, Submitted (31-DEC-1997) . 23, Unpublished                            |
+----------+--------------------------------------------------------------------------+

MySQL中的 `CONCAT` 和 `GROUP_CONCAT` 是两个常用的字符串处理函数,它们分别用于不同的场景,并且在功能和使用方式上有显著区别。 ### 1. `CONCAT` 函数 `CONCAT` 用于将多个字符串连接成一个单一的字符串。如果任意一个参数为 `NULL`,则整个结果也会是 `NULL`。该函数通常用于单条记录的字段拼接操作。 例如,可以将公司的名称和部门名称组合在一起显示: ```sql SELECT CONCAT(c.company_name, '-', d.dept_name) AS company_dept_name FROM sys_company c LEFT JOIN sys_dept d ON c.company_id = d.company_id; ``` 此查询会返回每一条记录中公司名与部门名通过短横线 `-` 拼接后的结果[^1]。 ### 2. `GROUP_CONCAT` 函数 `GROUP_CONCAT` 是一种聚合函数,主要用于在包含 `GROUP BY` 的查询中,将分组内的多行数据拼接成一个单独的字符串,默认使用逗号 `,` 作为分隔符。可以通过 `SEPARATOR` 关键字指定自定义的分隔符[^3]。 例如,当需要将每个公司的所有部门名称合并成一个字段时,可以使用如下查询: ```sql SELECT c.company_id, GROUP_CONCAT(DISTINCT d.dept_name SEPARATOR ',') AS dept_names FROM sys_company c LEFT JOIN sys_dept d ON c.company_id = d.company_id GROUP BY c.company_id; ``` 此查询的结果中,每个 `company_id` 对应的所有 `dept_name` 会被拼接成一个由逗号分隔的字符串[^1]。 ### 3. 主要区别 - **用途不同**: `CONCAT` 用于拼接同一行中的多个字段值;而 `GROUP_CONCAT` 用于将多行数据的某一字段值进行拼接。 - **是否属于聚合函数**: `GROUP_CONCAT` 是聚合函数,通常与 `GROUP BY` 配合使用;而 `CONCAT` 不是聚合函数,适用于每一行的字段拼接。 - **处理 NULL 值的方式**: 如果 `CONCAT` 中的任一参数为 `NULL`,则整个结果也为 `NULL`;而 `GROUP_CONCAT` 会忽略 `NULL` 值,不会将其纳入拼接结果中。 - **分组影响**: `GROUP_CONCAT` 必须配合 `GROUP BY` 使用,否则可能无法达到预期效果;而 `CONCAT` 不受分组影响,仅作用于当前行的数据。 ### 示例对比 假设表结构如下: #### 表 `sys_company`: | company_id | company_name | |------------|--------------| | 1 | Company A | | 2 | Company B | #### 表 `sys_dept`: | dept_id | dept_name | company_id | |---------|------------|------------| | 1 | HR | 1 | | 2 | Finance | 1 | | 3 | IT | 2 | #### 使用 `CONCAT` 查询: ```sql SELECT CONCAT(c.company_name, '-', d.dept_name) AS company_dept_name FROM sys_company c LEFT JOIN sys_dept d ON c.company_id = d.company_id; ``` **输出示例:** | company_dept_name | |---------------------| | Company A-HR | | Company A-Finance | | Company B-IT | #### 使用 `GROUP_CONCAT` 查询: ```sql SELECT c.company_id, GROUP_CONCAT(d.dept_name SEPARATOR ',') AS dept_names FROM sys_company c LEFT JOIN sys_dept d ON c.company_id = d.company_id GROUP BY c.company_id; ``` **输出示例:** | company_id | dept_names | |------------|--------------------| | 1 | HR,Finance | | 2 | IT | ### 注意事项 - `GROUP_CONCAT` 的结果长度受系统变量 `group_concat_max_len` 限制,默认值为 1024 字节。如需支持更长的字符串,可调整该值: ```sql SET SESSION group_concat_max_len = 1000000; ``` - 在使用 `GROUP_CONCAT` 时,建议加上 `DISTINCT` 来避免重复值被拼接进去,提高结果准确性。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值