mysql join on and

2018-6-4 10:28:50 星期一

开发中一直在用 left join, 心中只有一丝丝的了解, 还都是学校里学的, 今天看了几遍文章这里记录一下

sql的left join 、right join 、inner join之间的区别

  left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 
  right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录
  inner join(等值连接) 只返回两个表中联结字段相等的记录

参考

join 检索过程

先匹配ON中的条件, 然后再筛选where中的条件

"

ON 条件(“A LEFT JOIN B ON 条件表达式”中的ON)用来决定如何从 B 表中检索数据行。

如果 B 表中没有任何一行数据匹配 ON 的条件,将会额外生成一行所有列为 NULL 的数据,在匹配阶段 WHERE 子句的条件都不会被使用。

仅在匹配阶段完成以后,WHERE 子句条件才会被使用。它将从匹配阶段产生的数据中检索过滤。

"

参考

 

注意点:

1. 要保证返回结果正确的前提下再进行效率分析, 比如 left join 可能会产生多余的包含NULL的行, 要先决定这样的结果是否正确

2. inner join 要返回两边都符合on条件的记录, 所以 on中的匹配条件要作用于两个表, 而 left join 中的on只作用于右表

 

join on and

有时候会看到这样的写法:

1. A LEFT JOIN B ON A.id=B.id  AND b.status=0

2. A INNER JOIN B ON A.id=B.id  AND b.status=0

注意: 只有在用 inner join 的时候 AND b.status=0 才会起到筛选作用, 也就是在联结的时候, 只跟B表的status=0的字段进行联结, (如果数据量比较大或是连接的表比较多, 这个写法还是很省时间的)

而 1中left join 后边的 and 语句并不会起到筛选的作用

posted @ 2018-06-04 10:41  myD  阅读(634)  评论(0编辑  收藏  举报