规避笛卡尔积
笛卡尔积形成的条件:
1.查询语句中漏掉了连接条件
2.查询语句中两个表中的所有行都满足连接条件
3.查询语句中的连接条件无效
在实际工作中应该尽量的避免出现笛卡尔积,在多表连接查询语句的WHERE字句中,必须永远是用有效而正确的连接条件。
举例说明:select * from a,b,c where a.i = c.i and c.i = b.i
假设,我规定表JOIN的顺序是从左到右
a到b,b到c
那上面这个语句,虽然有两个关联条件,也会发生笛卡尔积
因为a和b没有字段直接关联,a和b两个表就要先笛卡尔积了。
正确写法:select * from a,b,c where a.i = b.i and b.i = c.i
那select * from a,b,c where a.i = b.i and a.i = c.i会不会发生笛卡尔积呢?
不会,因为a,b已经正常的join出结果,已经过滤了很多数据,然后再去跟c关联。(a,b)和(c)这两个结果集是有关联条件的,就是a.i = c.i
只有没有关联条件的,才会发生笛卡尔积!
在早期的版本,由于连接的顺序没有选对,造成了笛卡尔积。在新的版本,CBO自己会去判断,所以会避免笛卡尔积。