SQL 关键字 INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN和ON
- inner join,在两张表进行连接查询时,只保留两张表中完全匹配的结果集。
- left join,在两张表进行连接查询时,会返回左表所有的行,即使在右表中没有匹配的记录。
- right join,在两张表进行连接查询时,会返回右表所有的行,即使在左表中没有匹配的记录。
- full join,在两张表进行连接查询时,返回左表和右表中所有没有匹配的行(即2和3的并集)。
- 在使用 join 时,on 和 where 条件的区别如下(以left join为例子):
- on 条件是在生成临时表时使用的条件,它不管 on 中的条件是否为真,都会返回左边表中的记录。
- where 条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有 left join 的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。