mysql 多对多逗号分割,如何在一个以逗号分隔的列表中的一个字段中连接MySQL中的多对多关系中的数据?...

I have a many-to-many relationship between People and Departments since one person can be in many departments.

People Departments

------ -----------

pID pName deptID deptName

1 James 1 Engineering

2 Mary 2 Research

3 Paul 3 Marketing

4 Communications

People_Departments

------------------

pID deptID

1 1

1 2

2 2

2 4

3 1

3 2

3 3

What I want is this:

pName deptName

James Engineering, Research

Mary Research, Communication

Paul Engineering, Research, Marketing

If I do plain LEFT JOINs on the tables using the SQL below, I will get several rows related to one person:

SELECT people.pName,

departments.deptName

FROM people

LEFT JOIN people_departments ON people.pID=people_departments.pID

LEFT JOIN departments ON people_departments.deptID=departments.deptID

I have tried various combinations of GROUP_CONCAT but without luck.

Any ideas to share?

解决方案SELECT people.pName,

GROUP_CONCAT(departments.deptName SEPARATOR ', ') deptName

FROM people

LEFT JOIN people_departments

ON people.pID = people_departments.pID

INNER JOIN departments

ON people_departments.deptID = departments.deptID

GROUP BY people.pID

Output:

+-------+----------------------------------+

| pName | deptName |

+-------+----------------------------------+

| James | Engineering, Research |

| Mary | Research, Communications |

| Paul | Engineering, Research, Marketing |

+-------+----------------------------------+

3 rows in set (0.00 sec)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值