如何在3个表之间连接SQL查询

时间:2019-04-10 17:28:02

标签: mysql

我的数据库中有3个表,如下所示:

实验室

id
lab_name
lab_owner_id (references id in labs_members table)
lab_manager_id (references id in labs_members table)

labs_members

id
person_id (references id in labs_person table)

实验室人员

id
first_name
last_name

我需要构造一个查询以从实验室表中获取所有信息,包括实验室所有者和实验室经理的名字和姓氏。

我尝试了以下查询的变体:

SELECT labs.id, labs.lab_name, labs.lab_owner_id, labs.lab_manager_id
FROM labs
LEFT JOIN labs_members on labs.lab_owner_id = labs_members.id
LEFT JOIN labs_members on labs.lab_manager_id = labs_members.id
LEFT JOIN labs_person on labs_person.id = labs_members.person_id 
ORDER BY labs.lab_name ASC

但是,同时获得实验室经理和实验室所有者的名字并没有取得任何成功。我收到错误消息,或者是实验室管理员名称或实验室所有者名称(但不能同时出现)。

我们非常感谢您的协助。谢谢!

1 个答案:

答案 0 :(得分:1)

您非常非常接近。再加入一个人员表和一些表别名,您将在那里:

SELECT labs.id, labs.lab_name, labs.lab_owner_id, labs.lab_manager_id, owner_person.first_name, owner_person.last_name, manager_person.first_name, manager_person.last_name
FROM labs
LEFT JOIN labs_members as owner on labs.lab_owner_id = labs_members.id
LEFT JOIN labs_members as manager on labs.lab_manager_id = labs_members.id
LEFT JOIN labs_person as owner_person on owner_person.id = owner.person_id 
LEFT JOIN labs_person as manager_person on manager_person.id = manager.person_id 
ORDER BY labs.lab_name ASC