魏_寒冰人

导航

规避笛卡尔积

笛卡尔积形成的条件:

      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自己会去判断,所以会避免笛卡尔积。

 

 

posted on 2013-07-09 15:41  魏_寒冰人  阅读(725)  评论(0编辑  收藏  举报