Бонус: начислена 1 монета за дневную активность. Сейчас у вас 1 монета

Склеивание вывода SELECT в одну строку

Практика



Если Вам необходимо склеить вывод команды SELECT, представляющий собой некий набор строк, в одну строку, разделенную собственно заданным разделителем - вот решение. Для этого в MySQL используется оператор GROUP_CONCAT:

SELECT GROUP_CONCAT(expr SEPARATOR ',')

Например:

SELECT GROUP_CONCAT(title SEPARATOR ';') FROM mytable

вместо вывода нескольких строк с title выведет только одну, склеенную символом ';'. Вот изначальная таблица и результат запроса:

mytable
---
id  title
1   one
2   two
3   three

result
---
one;two;three



Другой пример:

SELECT (SELECT GROUP_CONCAT(mytable2.value SEPARATOR ':') FROM mytable2 WHERE mytable2.reason=mytable1.sourcevalue) FROM mytable1;

В этом примере мы извлекаем из таблицы mytable2 значения value строк, reason которых совпадает с sourcevalue первой таблицы, и выстраиваем это все в одну строку с разделителем ':' (несколько строк т.к. склеивание происходит для каждой строки mytable1). Вот пример таблиц и результата (для этого запроса):

mytable1:
---
sourcevalue
1
2
3

mytable2:
---
reason   value
1        A
1        B
2        C
3        D
4        E

result:
---
A:B
C
D


PS. ВНИМАНИЕ! У данной функции есть ограничение по-умолчанию на 1024 символа в объединенной строке. Чтобы это ограничение изменить - нужно выполнить следующий запрос (при наличии соответствующих прав):
SET group_concat_max_len = 16384;
где вместо 16384 указать максимальный размер объединенной строки в символах.
создано: 2017-05-09
обновлено: 2026-03-09
2022



Помог ли вам этот ответ?
Нажмите оценку и напишите коротко почему. Так мы сможем сделать следующие ответы точнее и полезнее.
Насколько вы довольны ответом?
Ваш отзыв напрямую влияет на качество следующих подсказок и ответов.


Поделиться:
Пожаловаться

Найди готовое или заработай

С нашими удобными сервисами без комиссии*

Как это работает? | Узнать цену?

Найти исполнителя
$0 / весь год.
  • У вас есть задание, но нет времени его делать
  • Вы хотите найти профессионала для выполнения задания
  • Возможно применение функции гаранта на сделку
  • Приоритетная поддержка
  • идеально подходит для студентов, у которых нет времени для решения заданий
Готовое решение
$0 / весь год.
  • Вы можете продать (как исполнитель) или купить (как заказчик) готовое решение
  • Вам предоставят готовое решение
  • Будет предоставлено в минимальные сроки т.к. задание уже готовое
  • Вы получите базовую гарантию 8 дней
  • Вы можете заработать на материалах
  • подходит как для студентов так и для преподавателей
Я исполнитель
$0 / весь год.
  • Вы профессионал своего дела
  • У вас есть опыт и желание зарабатывать
  • Вы хотите помочь в решении задач или написании работ
  • Возможно применение функции гаранта на сделку
  • подходит для опытных студентов так и для преподавателей

Комментарии

Оставить комментарий

Если у вас есть какое-либо предложение, идея, благодарность или комментарий, не стесняйтесь писать. Мы очень ценим отзывы и рады услышать ваше мнение.
To reply

Лекции и учебник по "Базы данных - MySql (Maria DB)"

Термины: Базы данных - MySql (Maria DB)