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 之间的映射以及一些附加数据。现在我需要编写一个查询来在基于 , 的连接字符串中显示valu
andpref
pid
所以反对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
任何帮助表示赞赏。