多表连接时条件放在 on 与 where 后面的区别
2017-08-07 17:15
369 查看
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 中,返回的结果集是相同的。
当连接条件有多个时:
1. 对于 left join, right join, full join,不管 on 上的条件是否为真都会返回 left(或 right)表的所有记录,full 则具有 left 和 right 的特性的并集。
2. 对于 inner join 就没有这个特殊性了,连接条件放在 on 中和 where 中,返回的结果集是相同的。
相关文章推荐
- 连接查询,条件在on和where后面的区别
- sql 左连接(left join),右链接(right join) 条件放在on和放在where 的区别
- join联表中on,where后面跟条件的区别
- LEFT JOIN ON 后面跟多个条件和Where的区别
- JOIN联表中ON,WHERE后面跟条件的区别
- left join 过滤条件写在on后面和写在where 后面的区别
- 转:SQL:外连接on条件与where条件的区别
- left join on、where后面的条件的区别
- 外连接 ON 条件的三个作用 SQL中on条件与where条件的区别
- SQL中过滤条件放在on和where中的区别
- JOIN关联表中ON,WHERE后面跟条件的区别
- JOIN关联表中ON,WHERE后面跟条件的区别
- 转:SQL:外连接on条件与where条件的区别
- left join 过滤条件写在on后面和写在where 后面的区别
- left join 过滤条件写在on后面和写在where 后面的区别
- 浅谈左连接 on和where条件的区别
- SQL中条件放在on后与where后的区别
- JOIN联表中ON,WHERE后面跟条件的区别
- 外连接 ON 条件的三个作用及与 WHERE 的区别
- SQL:外连接on条件与where条件的区别