一文关于谓词下推的SQL

本文探讨了SQL查询优化的技巧,强调了在内连接和左连接中条件的放置位置对查询性能的影响。优化策略包括:将保留表条件放在`WHERE`子句后,非保留表条件放在`ON`子句后;对于`LEFT JOIN`,非保留表的条件在`WHERE`中可能导致转换为`INNER JOIN`;同时指出在某些情况下,`ISNULL`在`LEFT JOIN`的`WHERE`子句中用于做差集可能无效。
摘要由CSDN通过智能技术生成

总结:优化--保留表条件写到 where后,非保留表条件写到 on后;

SQL题:

A表

clt_idclt_nam
1001A
1002B
1002B
1003C
1003C
1006F

B表

clt_idclt_nam
10011
10022
10033
10033
10033

1004

4

1005

5

1.ininer join 后面不论是否开启cbo,where 都可以,on不可以

2. left Join做差集A-B,where 后面接 非保留表 is null 做谓词下推没意义(开启cbo)

3.left Join 的on中对于非保留表可以谓词下推

4. 对于 left join的时候,如果where 后面接非保留表条件(cbo开启,可谓词下推),会将条件谓词下推到map端,同时将 left join 变为 inner join;

 5.保留表在 on字段后面不起作用,where 后面 非保留表 is null 进行做差集

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值