• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL基于group_concat()函数合并多行数据

mysql 搞代码 4年前 (2022-01-09) 26次浏览 已收录 0个评论

一个很有用的函数

group_concat(),手册上说明:该函数返回带有来自一个组的连接的非NULL值的字符串结果。

通俗点理解,其实是这样的:group_concat()会计算哪些行属于同一组,将属于同一组的列合并显示出来。要返回哪些列,由函数参数(就是字段名)决定。分组必须有个标准,就是根据group by指定的列进行分组。

合并的字段分隔符默认为逗号,可通过参数separator指定。

比如在student表中,有如下5条数据:

  

有要求如下:“小明”的两行成绩可以放在一行展示,“小红”的两行成绩也放在一行展示!

那么就可以使用

  SELECT name,group_concat(subject,score) FROM student group by name;

查询结果如下:

  

也可以自定义分隔符

  SELECT name,group_concat(subject,score separator ‘–‘) FROM student group by name;

查询结果如下:

    

如果不使用group by name;会怎么样呢?

  SELECT name,group_concat(subject,score本文来源gao@!dai!ma.com搞$$代^@码!网) FROM student;

查询结果如下(只展示一行了,跟name属性无关了):

  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL基于group_concat()函数合并多行数据

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址