SQL实现将多行记录合并成一行
我们在数据开发的过程中,经常会遇到这样的需求,就是将多行合并为一行,并且用特定字符隔开。
1.单列拼接

我们期望得到的数据是按照学校,将该学校所有学生的名字合成一个字段,如下图所示

这个时候我们就可以使用GROUP_CONCAT函数来实现这个需求
GROUP_CONCAT函数将group by产生的同一个分组中的值连接起来,返回一个字符串结果。group_concat函数首先根据group by指定的列进行分组,将同一组的列显示出来,并且用分隔符分隔。由函数参数(字段名)决定要返回的列如:
GROUP_CONCAT(字段 分隔符)
select school,GROUP_CONCAT(name,',') from student
group by school;
2.多列拼接
GROUP_CONCAT还能对多列的数据进行拼接

使用下面的sql可以实现多列拼接
select school,GROUP_CONCAT(name,';'class) from student
group by school;
得到数据如下

本文介绍如何使用SQL中的GROUP_CONCAT函数将多行记录合并为一行,包括单列拼接和多列拼接的方法,适用于数据整理和汇总场景。
4162

被折叠的 条评论
为什么被折叠?



