Mysql 如何跨3个表连接SQL查询

Mysql 如何跨3个表连接SQL查询,mysql,Mysql,我的数据库中有3个表,如下所示: 实验室 id lab_name lab_owner_id (references id in labs_members table) lab_manager_id (references id in labs_members table) id person_id (references id in labs_person table) 实验室成员 id lab_name lab_owner_id (references id in labs_members

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

实验室

id
lab_name
lab_owner_id (references id in labs_members table)
lab_manager_id (references id in labs_members table)
id
person_id (references id in labs_person table)
实验室成员

id
lab_name
lab_owner_id (references id in labs_members table)
lab_manager_id (references id in labs_members table)
id
person_id (references id in labs_person table)
labs\u person

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

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

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
但是,我没有成功地同时获得实验室经理和实验室所有者的姓名。我得到一个错误,或者是实验室经理的名字或者实验室所有者的名字(但不是两者都有)


非常感谢您的帮助。谢谢

你们非常接近。再加入一次person表和一些表别名,您将看到:

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
杰出的我不得不将“labs\u members.id”改为“owner.id”,将其他“labs\u members.id”改为“manager.id”。但是,除此之外,这是完美的!谢谢你的建议。