1.a join b on a.id=b.id and a.id is nul
2.a left join b on a.id =b.id and a.id is null
3.a left join b on a.id =b.id and b.id is null
4.a right join b on a.id =b.id and a.id is null
5.a right join b on a.id =b.id and b.id is null
比较and和where的区别,我们首先得搞懂join ,left join,right join的区别。
在join,内连接中,on后面的条件等于where;
在left join 和right join中,on后面的条件不管成不成立主表都会展示,因此on后面的条件仅仅是用来限制从表的,
核心:理解左连接的原理!左连接不管怎么样,左表都是完整返回的当只有一个条件a.id=b.id的时候:左连接就是相当于左边一条数据,匹配右边表的所有行,满足on后面的第一个条件a.id=b.id的进行返回当有两个条件的时候a.id=b.id and a.age>100(当第二个条件进行左表筛选时)就是左边这张表只有a.age>100的行,才会参与右表的每行匹配(但是a.age<100的行也会返回,只不过age<100的行是不可能匹配到右表的,因为根本不参加匹配)当有两个条件的时候a.id=b.id and b.monkey>100(第二个条件进行右表筛选)就是左边这张表每一行,参与右表的monkey>100的每一行的匹配