zoukankan      html  css  js  c++  java
  • 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 输出了错误信息,请与系统管理员联系。

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

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

  • 相关阅读:
    Mysql 5.7解压版安装
    Java Web 整合案例
    maven 创建Java web项目
    LintCode 数字三角形
    Hibernate 泛型Dao实现
    LintCode 将二叉查找树转换成双链表
    LintCode 删除链表中倒数第n个节点
    LintCode 二级制中有多少个1
    LintCode翻转二叉树
    SpringMVC 运行流程
  • 原文地址:https://www.cnblogs.com/chenshao/p/5566854.html
Copyright © 2011-2022 走看看