引言
今天我们来说一个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 举报,一经查实,本站将立刻删除。原文转载: 原文出处: