表1:user
    image.png
    表2:test
    image.png
    测试1:

    1. select * from users a
    2. LEFT JOIN test b on a.theme=b.username and b.type='jsj';

    image.png
    测试2:

    1. select * from users a
    2. LEFT JOIN test b on a.theme=b.username
    3. where b.type='jsj';

    image.png

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