MYSQL join..on 后的and 和where的区别

今天在写SQL的时候发现一个问题  明明加了条件却还是筛选出来了

运行平台:Mysql

目的:比较join......on 后面的and 和where的区别


用AND后的SQL和结果集。还是有383这条结果集

MYSQL join..on 后的and 和where的区别_第1张图片


用where后的SQL和结果集。没有了这条记录

MYSQL join..on 后的and 和where的区别_第2张图片


结论
1.where 是在两个表join完成后,再附上where条件

2.而 and 则是在表连接前过滤A表或B表里面哪些记录符合连接条件,同时会兼顾是left join还是right join。即
假如是左连接的话,如果左边表的某条记录不符合连接条件,那么它不进行连接,但是仍然留在结果集中(此时右边部分的连接结果为NULL)。on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。

3.建议尽量用where来过滤条件



你可能感兴趣的:(mysql)