Skip to content

GROUP_CONCAT

函数说明

GROUP_CONCAT 函数返回一个字符串,它将通过列或者表达式指定的内容连接起来。

如果结果集没有任何行,此函数将返回 NULL

函数语法

> GROUP_CONCAT(expr)

完整的语法如下:

GROUP_CONCAT([DISTINCT] expr [,expr ...]
             [ORDER BY {unsigned_integer | col_name | expr}
                 [ASC | DESC] [,col_name ...]]
             [SEPARATOR str_val])

参数释义

参数 说明
expr 必须参数。它指定了要连接的一个或者多个列或表达式。
DISTINCT 可选参数。它用于消除重复值。
ORDER BY 可选参数。它用于对要连接的内容排序。默认情况下,它按升序排序值。如果要按降序对值进行排序,则需要明确指定 DESC 选项。
SEPARATOR 可选参数。连接符。默认是 ,

返回值

返回值是一个非二进制或二进制字符串,这取决于参数 expr 是非二进制还是二进制字符串。

如果结果集没有任何行,此函数将返回 NULL

示例

create table t1(a int,b text,c text);
insert into t1 values(1,"a","bc"),(2,"ab","c"),(3,"aa","bb"),(3,"aa","bb");

mysql> select group_concat(distinct a,b,c separator '|') from t1;
+-----------------------------------+
| group_concat(distinct a, b, c, |) |
+-----------------------------------+
| 1abc|2abc|3aabb                   |
+-----------------------------------+
1 row in set (0.01 sec)

mysql> select group_concat(distinct b,c separator '|') from t1 group by a;
+--------------------------------+
| group_concat(distinct b, c, |) |
+--------------------------------+
| abc                            |
| abc                            |
| aabb                           |
+--------------------------------+
3 rows in set (0.01 sec)

mysql> select group_concat(distinct b,c separator '|') from t1;
+--------------------------------+
| group_concat(distinct b, c, |) |
+--------------------------------+
| abc|abc|aabb                   |
+--------------------------------+
1 row in set (0.01 sec)