Функция GROUP_CONCAT
складывает (как
строки) содержимое одного поля из разных
строк, вставляя между ними разделитель (по
умолчанию это запятая). К примеру, можно
получить список всех выбранных имен через
запятую или другой разделитель.
У этой функции есть ограничение на объем
выводимых данных. По умолчанию 1024
символа для каждого объединения - для каждой
выводимой строки. Если размер склеенных данных
больше, то он будет урезаться. Чтобы расширить
размер нужно выполнить команду SET group_concat_max_len
= 4096; Если у вас есть привилегии, то вы
расширите объем получаемых данных до 4096
,
можно и больше. Но чаще всего на обычных
хостингах таких привилегий нет.
Синтаксис
Без указания разделителя (по умолчанию это будет запятая):
SELECT GROUP_CONCAT(поле) FROM имя_таблицы WHERE условие
С указанием разделителя:
SELECT GROUP_CONCAT(поле SEPARATOR разделитель) FROM имя_таблицы WHERE условие
Таблицы для примеров
id айди |
name имя |
age возраст |
salary зарплата |
---|---|---|---|
1 | user1 | 23 | 400 |
2 | user2 | 25 | 500 |
3 | user3 | 23 | 500 |
4 | user4 | 30 | 900 |
5 | user5 | 27 | 500 |
6 | user6 | 28 | 900 |
Пример
В данном примере запрос находит все имена из таблицы и выводит их через запятую:
SELECT GROUP_CONCAT(name) as name FROM employees
Результат выполнения кода:
name имена |
---|
user1,user2,user3,user4,user5,user6 |
Пример
В данном примере разделитель меняется на
'+'
с помощью команды SEPARATOR
:
SELECT GROUP_CONCAT(name SEPARATOR '+') as name FROM employees
Результат выполнения кода:
name имена |
---|
user1+user2+user3+user4+user5+user6 |
Пример
В данном примере с помощью команды WHERE
выбираются не все строки, а заданные:
SELECT GROUP_CONCAT(name) as name FROM employees WHERE id>=3 AND id<=5
Результат выполнения кода:
name имена |
---|
user3,user4,user5 |
Пример
В данном примере с помощью команды GROUP BY строки группируются по возрасту и для каждой группы через запятую выводятся имена работников с таким возрастом:
SELECT age, GROUP_CONCAT(name) as name FROM employees GROUP BY age
Результат выполнения кода:
age возраст |
name имена |
---|---|
23 | user1,user2,user3 |
24 | user4,user5 |
25 | user6 |
Пример
Поменяем разделитель на '-'
:
SELECT age, GROUP_CONCAT(name SEPARATOR '-') as name FROM employees GROUP BY age
Результат выполнения кода:
age возраст |
name имена |
---|---|
23 | user1-user2-user3 |
24 | user4-user5 |
25 | user6 |