mysql 예제 여러 행과 테이블의 문자열을 하나의 결과 열로 연결할 수 있습니까?




mysql table inner join (2)

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)

테이블 "태그"와 일대 다 관계가있는 테이블 "프로젝트"에서 하나의 레코드를 검색하는 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'

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 가 소스 테이블의 모든 일치 레코드 (쉼표로 구분) @csv 쉼표로 구분 된 목록이된다는 @csv 입니다.

MySQL에서 시험해 볼만한 가치가 있습니까?





join