题目:
表: Person
表: Address
编写一个SQL查询来报告 Person 表中每个人的姓、名、城市和州。如果 personId 的地址不在 Address 表中,则报告为空 null 。
以 任意顺序 返回结果表。
查询结果格式如下所示。
示例 1:
输入以下两个表,然后进行输出
解释:
地址表中没有 personId = 1 的地址,所以它们的城市和州返回 null。
addressId = 1 包含了 personId = 2 的地址信息。
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/combine-two-tables
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路:
一看上面的示例,就可以看出需要联合两个表进行关联查询:
- 查询的字段在两个表都有,selct后面的字段应该和结果表一致,故应该写作:select firstName, lastName, city, state
- 有人没有地址信息,但是要查询所有的人,需要保留Person表中的信息,因此需要用到左连接;
- 两个表通过personId产生联结。
MySQL语句:
1 # Write your MySQL query statement below 2 select firstName, lastName, city, state 3 from person left join Address 4 on person.personId = Address.personId;
小知识:
1.多表联结:
- 左联结(left join):保留左表的全部数据;
- 右联结(right join):保留右表的全部数据;
- 内联结(inner join):取两表的公共数据;
2.on和where区别:
① 先执行on,后执行where;
②on是建立关联关系在生成临时表时候执行,where是在临时表生成后对数据进行筛选的。比如两个表进行left join连接查询结果,where会对查询的结果进行过滤, on会返回驱动表的所有数据。
③left join时,不管on条件是否成立,左表的所有行数据都会select出来(不管右表条件是否成立),右表成立就select对应数据,不成立就置null。有可能是一对多。
④当两张表是在left join来关联时,条件跟在on后面:无论on条件是否成立,都会返回左表的值;
⑤当两张表是在left join来关联时,当条件放在where后面时:只有满足条件的记录会返回。