首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何跨3个表连接SQL查询

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

Stack Overflow用户
提问于 2019-04-11 01:28:02
回答 1查看 11关注 0票数 0

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

实验

代码语言:javascript
复制
id
lab_name
lab_owner_id (references id in labs_members table)
lab_manager_id (references id in labs_members table)

labs_members

代码语言:javascript
复制
id
person_id (references id in labs_person table)

labs_person

代码语言:javascript
复制
id
first_name
last_name

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

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

代码语言:javascript
复制
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

然而,我还没有成功地同时获得实验室经理和实验室所有者的名字。我得到一个错误,或者是实验室经理名称或实验室所有者名称(但不是两个都有)。

任何帮助都是非常感谢的。谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-04-11 01:31:44

你已经非常非常接近了。再连接到person表和一些表别名,您就会看到:

代码语言:javascript
复制
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
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55618270

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档