· [Java论坛][安全论坛][数据库论坛][操作系统论坛]
· [推荐] 江民安全专家永久免费 立即下载  RSA 2010
· [专题] 谷歌遭黑客攻击事件 2010网页挂马爆发之年
· [IT技术周刊][IT资源下载专区][病毒求助专区]
· [热点] 《拆弹部队》藏木马 看Xbox360与PS3背后秘密
· [热点] 报告:PDF漏洞远超微软 十款免费电子邮件程序

快速掌握SQL Server中一些常见的性能问题 (1)

发布时间:2008.01.04 04:45     来源:赛迪网    作者:30331

SQL Server中一些常见的性能问题:

1.在对查询进行优化时,应当尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。

2.我们应当尽量避免使用 left join 和 null 值判断。left join 比 inner join 消耗更多的资源,因为它们包含与 null (不存在)数据匹配的数据,所以如果可以重新编写查询以使得该查询不使用任何 inner join ,则会得到相应的回报。

假如有两张示例表:

product(product_id int not null,product_type_id int null,...),产品表, product_id 为大于0的整数, product_type_id 与表 product_type 关联,但可为空,因为有的产品没有类别

product_type(product_type_id not null,product_type_name null,...),产品类别表

此时要关联两表后查询 product 的内容,马上会想到使用 inner join ,但下面有一种方法可避免使用 inner join :

在 product_type 中增加一条记录:0,'',...,并将 product 的 product_type_id 设置为 not null ,当产品没有类别时将其 product_type_id 设为0,这样查询就可以使用 inner join 了。

3.应尽量避免在 where 子句中使用!=或<>操作符,否则引擎可能放弃使用索引而进行全表扫描。

4.应尽量避免在 where 子句中使用 or 来连接条件,否则将可能导致引擎放弃使用索引而进行全表扫描,如有表 t , key1 、 key2 上建有索引,需要下面的存储过程:

create   procedure   select_proc1   @key1   int=0,@key2   int=0   
  as   
  begin   
      select   key3   from   t   
      where   (@key1=0   or   key1=@key1)   
          and   (@key2=0   or   key2=@key2)   
  end   
  go   
  这个存储过程会导致全表扫描,可作如下修改:
  create   procedure   select_proc2   @key1   int=0,@key2   int=0   
  as   
  begin   
  if   @key1   <>0   and   @key2<>0   
  select   key3   from   t   
  where   key1=@key1   and   key2=@key2   
  else   
  if   @key1<>0   
  select   key3   from   t   where   key1=@key1   
  else   
  select   key3   from   t   where   key2=@key2   
  end   
  go

更改后虽然代码增加了,但效率提高了。

5.in 和 not in 也要慎用,如:

select   id   from   t   where   num   in(1,2,3)

1 2 3 下一页>>


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
资讯 通信 IT产品 IT技术 信息化
3.15赛迪网特别策划:消费者不是消“废”者
·专题:惠普栽在3.15前..
·深度观察:中国新能源汽..
·焦点解读:纯电动汽车能..
专题:三网融合 看起来很美!
·专题:动力100——助企..
·专题:三大运营商"扎堆"..
·专题:谷歌推智能手机Ne..
专题:回顾2009 原装耗材与兼容耗材发展
·专题:HP Photosmart Pl..
·专题:超薄超强 戴尔推..
·2009赛迪网年终评选 惠..
专题:RSA 2010信息安全大会
·专题:谷歌遭黑客攻击事..
·无处不挂马 2010年网页..
·龙存科技:由BizSpark成..