规避笛卡尔积

笛卡尔积形成的条件:

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

 

 

转载于:https://www.cnblogs.com/hanbingren/p/3180152.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值