多表连接时条件放在 on 与 where 后面的区别

DB 查询表之间做 join 时没有 on 条件会导致笛卡尔积,影响性能,必须避免,所以 on 后至少要跟一个连接条件(a.bid = b.bid)。
当连接条件有多个时:
1. 对于 left join, right join, full join,不管 on 上的条件是否为真都会返回 left(或 right)表的所有记录,full 则具有 left 和 right 的特性的并集。
2. 对于 inner join 就没有这个特殊性了,连接条件放在 on 中和 where 中,返回的结果集是相同的。

原文地址:https://www.cnblogs.com/kingsniper13/p/7300129.html