优化查询的几点建议之一

以下建议, 适用SQL SERVER 05, 08, 08R2, 2012

1,OR 在 WHERE 中

没有问题的:

  • WHERE a.col1 = @val1 OR a.col1 = @val2 …
  • WHERE a.col1 = @val1 OR a.col2 = @val2 …
  • WHERE a.col1 = @val1 OR a.col2 IN (SELECT col2 FROM tab2)

有问题的:
  • WHERE a.col1 = @val1 OR b.col2 = @val2

2,聚合在中间结果集合

GROUP BY OR DISTINCT 在中间结果集合,导致差的表现。解决办法是,把中间结果放入临时表。

3,大量复杂查询

表现于大量JOINS, 特别是在JOIN在区间,导致逐渐降低集的势(CARDINALITY)估计。可以拆分查询,加入临时表,予以处理。

4,CASE 在 WHERE OR JOIN 中

这种查询同样导致降低集的势(CARDINALITY)估计。处理办法是,分解CASE成独立查询,使用T-SQL的IF代替。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值