我在人员和部门之间存在多对多关系,因为一个人可以在多个部门中。
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
我想要的是这样的:
pName deptName
James Engineering, Research
Mary Research, Communication
Paul Engineering, Research, Marketing
如果我使用下面的 SQL 在表上执行简单的 LEFT JOIN,我将获得与一个人相关的几行:
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
我尝试了各种组合,GROUP_CONCAT
但没有运气。
有什么想法可以分享吗?