#3分钟短文 | MySQL在分组时,把多列合并为一个字段!
引言
今天我们来说一个MySQL查询的例子,比如有一个统计需求, 分组后的数据,我们知道只能使用聚合函数进行统计, 那如果要根据分组约定,将一系列的值合并到单个字段显示出来, 应该怎么写呢?
学习时间
首先我们准备数据,有一个用户喜好表,记录了用户的喜好。比如这样:
|
|
结果很多行数据:
|
|
那么问题来了,如果需要的输出类似于
|
|
一行展示就够了,不要多行展示,应该怎么写呢?或者说MySQL有没有这个能力处理呢?
当然是有的。MySQL贴心地给出了 GROUP_CONCAT
函数,用于使用分隔符连接多行字段的值。
比如说按照 person_id
进行分组,然后第二列输出用户喜好,使用逗号分隔符:
|
|
当然了,peoples_hobbies
表完全有可能在 hobbies
字段有重复的值,我们也可以进行唯一性筛选。
把上述SQL语句改造一下:
|
|
写到这里基本上已经可以满足使用了。可是我们还可以再进一步。 比如对我们的输出字段进行排序后再使用分隔符连接。
|
|
MySQL默认的单行字符数是1024,如果连接过多字段导致超出长度限制的,可以在查询之前修改变量:
|
|
有的同学会说了,这次查询你改成2048,勉强过关,随着时间的增长,数据量也在增长, 这个字符串长度也是动态的,能不能自动计算出来, 省的我们每次都要重新设置,重新计算,毕竟在查询之前,谁也不知道会有多少数据出来。 当然,MySQL提供的几个简单函数,就可以轻而易举地实现。
|
|
实时计算返回的字段长度值,实时修改限制变量值,是不是轻松了许多!
写在最后
今天通过一个示例,给大家展示了MySQL内置函数 group_concat
的用法,相信下次遇到要把多行合并为一行的需求,
你也能够轻松搞定了。
Happy coding :-)
我是@程序员小助手,专注编程知识,圈子动态的IT领域原创作者。