网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > 数据库技术 > Oracle > 性能调优 > SQL Server调优实战-性能调优  

SQL Server调优实战-性能调优

2008-07-24  作者:bitsCN整理  来源:中国网管联盟  点评 投稿 收藏

          今天调优某电信的大型数据库,是一个日志型的表,其中有个自增列字段和时间(时间是每个小时小时来的,每个小时有大概23万条记录),以及点击次数等日志信息,数据量在4000万以上,sp_spaceused使用了大概2G多的磁盘空间。整个表没有分区。整个表都是插入查询,没有更新操作。
         
          有一个基于时间字段上的时间段where范围选择,然后聚合找到某些类型的聚合值。
         
          观察发现自增列字段就是一个摆设,没有任何作用,也不做任何表的外键,只是可能当时开发人员在设计表的时候就不管3721都来一个自增列主键,导致在对date字段上的非聚集索引扫描后,还需要去聚集索引树上seek一下,这下子就增加一个嵌套查询了。去掉表上的主键聚集索引,将表回归为堆,这样在非聚集索引扫描后直接就拿到RID找相应行了。
         
          后来又想办法整了个date字段上的include索引,将要汇总的字段都加到非聚集索引上来,连RID查找都不要了。include虽然增加磁盘开销,但是速度上去很多,且没有针对索引的更新,不涉及索引拆分等费时操作,所以觉得还是值得。

网管论坛bbs_bitsCN_com

         
          最后优化结果,由45秒到20秒。
         
          优化结果还比较满意,最后最重要的是因为IO始终将不下来,因为数据太多了。
         
          不知道还有没有办法能想想的。
         
          其实以前自己在设计数据库的时候也经常对表开始就来一个主键,而并没有考虑其实际意义,导致表的操作非常困难。
         
          这个日志类型的表基本不需要自增主键字段,他不会根据某一日志ID范围来查找或者更新日志。
         
          但在优化的时候有个问题觉得很奇怪: 网管u家www.bitscn.net

            4000万的数据,查找其中的2万条,根据日期上的过滤,我想应该是一个嵌套的书签查询计划,结果看到MSSQL给出的答案却是聚集索引扫描。4000万比2万的数据,却宁愿表扫描而不愿意做嵌套?只有指定了使用非聚集索引后查询计划才改成嵌套的书签查询。 网管u家u.bitsCN.com

TAGs   性能   实战       索引   聚集   一个   没有   查询   扫描   数据      
 上一篇:在Oracle 11g数据库中实现自我调整功能-性能调优   下一篇:ORACLE 11i GL 设置逻辑-性能调优
SQL Server调优实战-性能调优 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
最新推荐文章:
网管论坛交流: