> 文章列表 > SQL - GROUP_CONCAT函数

SQL - GROUP_CONCAT函数

SQL - GROUP_CONCAT函数

        在SQL中,GROUP_CONCAT函数用于将一列中的多个值合并成一个字符串,通常用于分组查询时将分组内的数据合并为一个字符串。

语法:

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

参数说明:

- expr:要合并的列或表达式;
- DISTINCT:可选参数,表示去重,如果指定了DISTINCT,则合并后的字符串中不会包含重复的值;
- ORDER BY:可选参数,用于指定合并后的字符串的排序方式;
- ASC/DESC:可选参数,用于指定排序的方向;
- SEPARATOR:可选参数,用于指定合并后的字符串中各个值之间的分隔符,默认为逗号。
 

示例:

假设有以下表:

id name class
1 张三 一班
2 李四 一班
3 王五 二班
4 赵六 二班
...

如果我们要按照班级分组,并将每个班级中的学生姓名合并为一个字符串,可以使用以下SQL语句:

SELECT class, GROUP_CONCAT(name) AS students FROM table_name GROUP BY class;

执行结果如下:

class students
一班 张三,李四
二班 王五,赵六

由此可以看到,GROUP_CONCAT函数将每个班级中的学生姓名合并为了一个字符串,并以逗号作为分隔符,最终返回了每个班级的名称和学生姓名字符串。