mysql将多条数据合并成一条

引言

今天我们来说一个MySQL查询的例子,比如有一个统计需求, 分组后的数据,我们知道只能使用聚合函数进行统计, 那如果要根据分组约定,将一系列的值合并到单个字段显示出来, 应该怎么写呢?

mysql将多条数据合并成一条

学习时间

首先我们准备数据,有一个用户喜好表,记录了用户的喜好。比如这样:

SELECT hobbies FROM peoples_hobbies WHERE person_id = 5; 

结果很多行数据:

shopping
fishing
coding 

那么问题来了,如果需要的输出类似于

shopping, fishing, coding 

一行展示就够了,不要多行展示,应该怎么写呢?或者说MySQL有没有这个能力处理呢?

当然是有的。MySQL贴心地给出了 GROUP_CONCAT 函数,用于使用分隔符连接多行字段的值。 比如说按照 person_id 进行分组,然后第二列输出用户喜好,使用逗号分隔符:

SELECT person_id, GROUP_CONCAT(hobbies SEPARATOR ', ') AS all_hobbies FROM peoples_hobbies GROUP BY person_id; 

当然了,peoples_hobbies 表完全有可能在 hobbies 字段有重复的值,我们也可以进行唯一性筛选。 把上述SQL语句改造一下:

SELECT person_id, GROUP_CONCAT(DISTINCT hobbies SEPARATOR ', ') AS all_hobbies FROM peoples_hobbies GROUP BY person_id; 

写到这里基本上已经可以满足使用了。可是我们还可以再进一步。 比如对我们的输出字段进行排序后再使用分隔符连接。

SELECT person_id, GROUP_CONCAT(hobbies ORDER BY hobbies ASC SEPARATOR ', ') AS all_hobbies FROM peoples_hobbies GROUP BY person_id; 

MySQL默认的单行字符数是1024,如果连接过多字段导致超出长度限制的,可以在查询之前修改变量:

SET group_concat_max_len = 2048; 

有的同学会说了,这次查询你改成2048,勉强过关,随着时间的增长,数据量也在增长, 这个字符串长度也是动态的,能不能自动计算出来, 省的我们每次都要重新设置,重新计算,毕竟在查询之前,谁也不知道会有多少数据出来。 当然,MySQL提供的几个简单函数,就可以轻而易举地实现。

SET group_concat_max_len = CAST((SELECT SUM(LENGTH(hobbies)) + COUNT(*) * LENGTH(', ') FROM peoples_hobbies GROUP BY person_id) AS UNSIGNED); 

实时计算返回的字段长度值,实时修改限制变量值,是不是轻松了许多!

写在最后

今天通过一个示例,给大家展示了MySQL内置函数 group_concat 的用法,相信下次遇到要把多行合并为一行的需求, 你也能够轻松搞定了。

Happy coding :-)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至2705686032@qq.com 举报,一经查实,本站将立刻删除。原文转载: 原文出处:

(0)
尊云-小张的头像尊云-小张
上一篇 2024 年 5 月 23 日
下一篇 2024 年 5 月 23 日

相关推荐

发表回复

登录后才能评论

联系我们

400-900-3935

在线咨询: QQ交谈

邮件:cong@zun.com

工作时间:365天无休服务 24小时在线

添加微信