MySQL与Group By的一对多连接仅返回一个观察

Jus*_*tin 10 mysql join

我有一个评论表和一个标签表.对于每个评论,可能有多个标签,或者没有.我想加入这两个,所以我可以得到每个评论的标签列表.

CommentTable:

+---------+----------+---+
|CommentID|   Title  | ..|
+---------+----------+---+
|   1     |   animals|   |
|   2     |   plants |   |
+---------+----------+---+
Run Code Online (Sandbox Code Playgroud)

TagTable:

+---------+----------+---+
|  TagID  |CommentID | ..|
+---------+----------+---+
|    5    |     1    |   |
|    6    |     1    |   |
|    7    |     3    |   |
+---------+----------+---+
Run Code Online (Sandbox Code Playgroud)

因此,查询应返回标记,(5,6)表示commentID == 1,空数组表示CommentID == 2

这就是我所拥有的 - 它只选择最后一个ID而不是倍数:

SELECT c.CommentID, c.Title,  t.TagID  FROM Comment as c
        LEFT OUTER JOIN Tag as t ON c.CommentID = t.CommentID
        GROUP BY t.TagID
Run Code Online (Sandbox Code Playgroud)

Zan*_*ien 28

您可以使用GROUP_CONCAT将多行中的数据转换为单个分隔的字符串:

SELECT    a.CommentID, 
          a.Title,
          GROUP_CONCAT(b.TagID ORDER BY b.TagID) AS tags
FROM      CommentTable a
LEFT JOIN TagTable b ON a.CommentID = b.CommentID
GROUP BY  a.CommentID,
          a.Title
Run Code Online (Sandbox Code Playgroud)

在这种情况下,如果注释没有相应的标记,则该字段将只为NULL.


SQLFiddle演示

  • 太棒了......我很欣赏这种努力.我第一次看到SQLFiddle. (3认同)