• 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 输出了错误信息,请与系统管理员联系。

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

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

  • 相关阅读:
    新博客即将启用
    关于博主 | 联系博主
    结束吧,为这不圆满的故事划上一个残缺的句号
    自用线段树模板
    NOIP 2017 day 1 游记
    NOIP 2017 Day 0. 游记
    NOIP 2017 day -1 杂记
    再一次想不出应该起什么标题
    做图与树做到吐的一天
    自用二分图匹配模板
  • 原文地址:https://www.cnblogs.com/chenshao/p/5566854.html
Copyright © 2020-2023  润新知