Join的几种类型

笛卡尔积(交叉连接)
如果A表有n条记录,B表有m条记录,笛卡尔积产生的结果就会产生n*m条记录。
在MySQL中可以为CROSS JOIN或者省略CROSS即JOIN,或者直接用from多表用逗号分开。
如
SELECT * FROM table1 CROSS JOIN table2 SELECT * FROM table1 JOIN table2 SELECT * FROM table1 , table2
不用on table1.key1 = table2.key2 得出的结果是table1的记录数*table2的记录数,如果用on连接,得出的和inner join的结果一样(所以在有on的情况下,inner joijn、cross join、 join(推荐、会自动用小的表作为驱动表)结果一样)。
内连接:INNER JOIN
内连接INNER JOIN是最常用的连接操作。从数学的角度讲就是求两个表的交集,从笛卡尔积的角度讲就是从笛卡尔积中挑出ON子句条件成立的记录。有INNER JOIN,WHERE(等值连接),STRAIGHT_JOIN,JOIN(省略INNER)四种写法。
左【外】连接:LEFT [out] JOIN
左连接LEFT JOIN的含义就是求两个表的交集外加左表剩下的数据。依旧从笛卡尔积的角度讲,就是先从笛卡尔积中挑出ON子句条件成立的记录,然后加上左表中剩余的记录(见最后三条)。
右【外】连接:RIGHT [out] JOIN
同理右连接RIGHT JOIN就是求两个表的交集外加右表剩下的数据。再次从笛卡尔积的角度描述,右连接就是从笛卡尔积中挑出ON子句条件成立的记录,然后加上右表中剩余的记录(见最后一条)。
全外连接:Full outer join
select *,if(a.date is null,b.date,a.date) as date from a left join b on a.date = b.date -- 只有a的全部 union -- union上面的复制下来left改为right,连个表头要一致 select *,if(a.date is null,b.date,a.date) as date from a right join b on a.date = b.date
查询存在于一张表不存在于另一张表的sql
select ta.* from ta where ta.id not in(select tb.id from tb) /*效率低*/ select ta.id from ta left join tb on ta.id=tb.id where tb.id is NULL /*优化*/
本文深入解析了SQL中的各种连接类型,包括笛卡尔积、内连接、左连接、右连接及全外连接的概念与应用场景,同时提供了优化JOIN操作的实用技巧。
1821

被折叠的 条评论
为什么被折叠?



