Можно ли объединить строки из нескольких строк и таблиц в один столбец результатов? - PullRequest
9 голосов
/ 29 декабря 2008

Я пытаюсь написать запрос MySQL, который извлекает одну запись из таблицы «проекты», которая имеет отношение «один ко многим» с «тегами» таблицы. Мое приложение использует для этого 4 таблицы:

Projects - the projects table
Entities - entity table; references several application resources
Tags - tags table
Tag_entity - links tags to entities

Можно ли написать запрос таким образом, чтобы несколько значений из таблицы "Теги" были объединены в один столбец результатов? Я бы предпочел сделать это без использования подзапросов.

Таблица уточнения:

                                      -------------
                                     | Tag_Entity  |
 -------------       ----------      | ----------- |      -------
| Projects    |     | Entities |     | - id        |     | Tags  |
| ----------- |     | -------- |     | - tag_id    |     | ----- |
| - id        | --> | - id     | --> | - entity_id | --> | id    |
| - entity_id |      ----------       -------------      | name  |
 -------------                                            -------

Желаемый результат:

Projects.id   Entities.id   Tags.name (concatenated)
1             5             'foo','bar','etc'

Ответы [ 2 ]

20 голосов
/ 29 декабря 2008

см. GROUP_CONCAT

пример:

mysql> SELECT * FROM blah;
+----+-----+-----------+
| K  | grp | name      |
+----+-----+-----------+
|  1 |   1 | foo       |
|  2 |   1 | bar       |
|  3 |   2 | hydrogen  |
|  4 |   4 | dasher    |
|  5 |   2 | helium    |
|  6 |   2 | lithium   |
|  7 |   4 | dancer    |
|  8 |   3 | winken    |
|  9 |   4 | prancer   |
| 10 |   2 | beryllium |
| 11 |   1 | baz       |
| 12 |   3 | blinken   |
| 13 |   4 | vixen     |
| 14 |   1 | quux      |
| 15 |   4 | comet     |
| 16 |   2 | boron     |
| 17 |   4 | cupid     |
| 18 |   4 | donner    |
| 19 |   4 | blitzen   |
| 20 |   3 | nod       |
| 21 |   4 | rudolph   |
+----+-----+-----------+
21 rows in set (0.00 sec)

mysql> SELECT grp, GROUP_CONCAT(name ORDER BY K) FROM blah GROUP BY grp;
+-----+----------------------------------------------------------------+
| grp | GROUP_CONCAT(name ORDER BY K)                                  |
+-----+----------------------------------------------------------------+
|   1 | foo,bar,baz,quux                                               |
|   2 | hydrogen,helium,lithium,beryllium,boron                        |
|   3 | winken,blinken,nod                                             |
|   4 | dasher,dancer,prancer,vixen,comet,cupid,donner,blitzen,rudolph |
+-----+----------------------------------------------------------------+
4 rows in set (0.00 sec)
3 голосов
/ 29 декабря 2008

Я не знаю, работает ли он в MySQL, но в SQL Server вы можете использовать хитрость для этого:

DECLARE @csv varchar(max)
SET @csv = ''
SELECT @csv = @csv + ',' + foo.SomeColumn
FROM   [FOO] foo
WHERE  foo.SomeId = @SomeId

Затем в основном выберите

SELECT ..., @csv AS [Tags]
FROM ...

Результатом строки SELECT @csv = @csv + ',' + foo.SomeColumn является то, что @csv становится разделенным запятыми списком всех соответствующих записей из исходной таблицы (после предиката).

Стоит попробовать в MySQL?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...