SQLServer2005重建索引

今天发现一个页面运行很慢,用SQL Server Profiler抓出了一条运行时间为12s的sql

select * from v_wf_todo_business where dtinstance in (select dtinstance from t_wf_todo_business_sign_user where userid=244 union select dtinstance from t_wf_handle_state where handleuserid=244) and wfinstance is not null and wftbrq>='2016-05-07' and wftbrq<='2016-06-07'

把生产环境的数据库备份下来,还原到开发环境进行分析,发现只要把wftbrq>='2016-05-07'改为wftbrq>='2011-05-07',执行时间变正常了,只需要0.04s,差点以为我眼花了,时间范围变大,速度还更快了?

顿时明白了这肯定不是sql的问题,记得以前有个dba跟我说过重建索引能提高查询速度,所以就按照这里的方法进行尝试:http://www.cnblogs.com/luckybird/archive/2012/06/11/2544753.html

一、分析表的索引建立情况:DBCC showcontig('t_wf_todo_business')

 1 DBCC SHOWCONTIG 正在扫描 't_wf_todo_business' 表...
 2 表: 't_wf_todo_business' (1652200936);索引 ID: 1,数据库 ID: 7
 3 已执行 TABLE 级别的扫描。
 4 - 扫描页数................................: 1198
 5 - 扫描区数..............................: 188
 6 - 区切换次数..............................: 1196
 7 - 每个区的平均页数........................: 6.4
 8 - 扫描密度 [最佳计数:实际计数].......: 12.53% [150:1197]
 9 - 逻辑扫描碎片 ..................: 99.33%
10 - 区扫描碎片 ..................: 98.94%
11 - 每页的平均可用字节数........................: 2613.5
12 - 平均页密度(满).....................: 67.71%
13 DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

二、重建索引:DBCC DBREINDEX('t_wf_todo_business')

三、再来分析:DBCC showcontig('t_wf_todo_business')

 1 DBCC SHOWCONTIG 正在扫描 't_wf_todo_business' 表...
 2 表: 't_wf_todo_business' (1652200936);索引 ID: 1,数据库 ID: 7
 3 已执行 TABLE 级别的扫描。
 4 - 扫描页数................................: 804
 5 - 扫描区数..............................: 105
 6 - 区切换次数..............................: 104
 7 - 每个区的平均页数........................: 7.7
 8 - 扫描密度 [最佳计数:实际计数].......: 96.19% [101:105]
 9 - 逻辑扫描碎片 ..................: 0.87%
10 - 区扫描碎片 ..................: 98.10%
11 - 每页的平均可用字节数........................: 221.3
12 - 平均页密度(满).....................: 97.27%
13 DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

 

嗯嗯,发现扫描页数、区切换次数、扫描密度 [最佳计数:实际计数]、逻辑扫描碎片等指标都有大幅度好转。

在生产环境上也执行了一遍,再打开页面,发现一切正常了……

转载于:https://www.cnblogs.com/chenshao/p/5566854.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值