0
table 1
--------
pid | name
1    someone
2    another


table2
--------
bid | valu
1     drum
2     guitar
3     flower
4     cake


table3
------
id | pid | bid | pref
1    1     3     yes
2    1     1     maybe
3    1     2     no
4    2     4     definately
5    2     2   
6    2     3     no

如您所见,我有 3 个简单的表,其中第三个用于创建表 1 和 2 之间的映射以及一些附加数据。现在我需要编写一个查询来在基于 , 的连接字符串中显示valuandprefpid

所以反对pid = 1,预期的输出是这样的 flower yes, drum maybe, guitar no......所以我该如何编写这个查询?

我试过(几乎是盲目的猜测):

SELECT opa.name, GROUP_CONCAT(CONCAT(opb.valu,' ',opc.pref) SEPARATOR ',') AS myChoice
 From
     table_1 opa
 INNER JOIN table_3 opc ON opc.pid = opa.pid
 INNER JOIN table_2 opb ON opb.bid = opc.bid

任何帮助表示赞赏。

4

1 回答 1

2

您的查询是正确的您只是忘记了GROUP BY

 SELECT opa.name, GROUP_CONCAT(CONCAT(opb.valu,' ',opc.pref) SEPARATOR ',') AS myChoice
 From
 table1 opa
 INNER JOIN table3 opc ON opc.pid = opa.pid
 INNER JOIN table2 opb ON opb.bid = opc.bid
 group by opc.pid

在这里演示

于 2013-04-03T12:11:35.493 回答