在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函数将每个班级中的学生姓名合并为了一个字符串,并以逗号作为分隔符,最终返回了每个班级的名称和学生姓名字符串。