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:可选参数,用于指定合并后的字符串中各个值之间的分隔符,默认为逗号。
 

示例:

假设有以下表:

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

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

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

执行结果如下:

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

别晃我的可乐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值