表1:user
表2:test
测试1:
select * from users aLEFT JOIN test b on a.theme=b.username and b.type='jsj';

测试2:
select * from users aLEFT JOIN test b on a.theme=b.usernamewhere b.type='jsj';

从上述结果知道, left join会将左表的所有记录都显示出来,而在右表不匹配on条件的数据行则该列显示为Null。
而where条件由于在left join之外,所以是对连接之后的结果再次过滤。
在使用left jion时,on和where条件的区别如下:
1、on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。
2、where条件是在临时表生成好后,再对临时表进行过滤的条件。
