我正在尝试创建一个MySQL SELECT语句,它将从表中选择一堆行,并将结果按行的id分组(多行将具有相同的id)。
这是我正在尝试做的一个例子。假设我有下表:
id | name
1 | Art
1 | Arnold
1 | Anatoly
2 | Beatrice
2 | Bertha
2 | Betty
3 | Constantine
3 | Cramer
我想让MySQL返回按ID分组的数据,如下所示:
[1] => Art, Arnold, Anatoly
[2] => Beatrice, Bertha, Betty
[3] => Constantine, Cramer
我知道我可以做一个简单的SQL选择,然后在PHP中循环结果,但是如果可能的话我想让MySQL处理分组。
答案 0 :(得分:4)
一种可能的解决方案是使用MySQL的GROUP_CONCAT(expr)函数。
SELECT
GROUP_CONCAT(name)
FROM
foo
GROUP BY
id
但请记住:
结果被截断为group_concat_max_len系统变量给出的最大长度,该变量的默认值为1024.