当前位置:  数据库>sqlserver

如何对SQL Server 重建索引

    来源: 互联网  发布时间:2014-08-29

    本文导语:      我们知道重建索引是为了减少数据碎片。数据碎片会导致 SQL Server 进行不必要的数据读,降低 SQL Server 的性能。重建索引也会同时更新列统计,而如果查询所使用的列缺少或遗漏统计信息,这可能导致 SQL Server 内部的优化...

    我们知道重建索引是为了减少数据碎片。数据碎片会导致 SQL Server 进行不必要的数据读,降低 SQL Server 的性能。重建索引也会同时更新列统计,而如果查询所使用的列缺少或遗漏统计信息,这可能导致 SQL Server 内部的优化器选择比预期效率低的查询计划。

    如果您重建了某张表上的聚集索引,该表上的非聚集索引也同时会被更新。

    要更新索引,您可以使用 Maintenance Wizard (相关内容您可以参考 http://msdn.microsoft.com/en-us/library/ms180074.aspx ),或在 SQL Server 代理( Agent )中运行如下的自定义代码来更新某个数据库中所有表上的索引:
 

代码如下:

USE DatabaseName --Enter the name of the database you want to reindex

DECLARE @TableName varchar ( 255)
DECLARE TableCursor CURSOR FOR
SELECT table_name FROM information_schema . tables

WHERE table_type = 'base table'

OPEN TableCursor
FETCH NEXT FROM TableCursor INTO @TableName

WHILE @@FETCH_STATUS = 0
BEGIN

DBCC DBREINDEX( @TableName, ' ' , 90)
FETCH NEXT FROM TableCursor INTO @TableName

END

CLOSE TableCursor

DEALLOCATE TableCursor

    可以根据您的需求修改 DBREINDEX 的参数。

    需要注意的是,重建非聚集索引时该表会暂时加上共享锁,对用户不可进行 SELECT 以外的操作;重建聚集索引时该表会暂时加上排外锁,不允许任何用户访问。因此需要制定好计划来预防可能的访问问题。

    REBUILD 有一个 fill factor 参数,如果 fill factor 设置为 100% ,这意味着每一个索引页都是完全满的,如果 fill factor 设置为 50% 意味着每个索引页都是半满的。对于 fill factor 100% ,每次新插入或更新一个记录,由于当前页没有空间可用,可能有分页情况产生。过多的分页会降低 SQL Server 的性能。下面具体举个例子:

    假设您在一张表上建立了一个使用默认 fill factor 的新索引。当 SQL Server 创建索引时,它会把索引放置在连续的物理页上,以使数据顺序地被读, I/O 访问最优化。但当表因 INSERT , UPDATE , DELETE 等操作增长改变时,分页发生, SQL Server 在磁盘的其他地方分配新的页,导致新的页与原物理页不连续,增加了随机 I/O ,访问索引页变慢。

    那么 fill factor 的合适值应该为多少?这取决于表的读 / 写比:
    低更新表(读 / 写比: 100 比 1 ): 100% fill factor
    高更新表(写超过读): 50%-70% fill factor
    居中: 80%-90% fill factor

    过低的 fill factor 会增加页的数量,也会导致更多的页需要被移至缓存,缓存中有用的数据减少。默认的 fill factor 为 0 (即 100% fill factor ),通常这不是个好的选择,特别是对于聚集索引。

    如果您无法判断设置什么 fill factor, 您首先需要确定磁盘的读 / 写比 . 方法就是使用如下两个计数器:
Physical Disk Object: % Disk Read Time 和 Physical Disk Object: % Write Time 。另外一个可能有用的计数器就是: SQL Server Access Methods: Pages Splits/Sec 。这个计数器测量 SQL Server 内每秒分页的次数。如果该数值过高,您需要降低 fill factor 防止新的分页。

    如果您想确认您的索引因分页产生的碎片程度,您可以运行 DBCC SHOWCONTIG 命令。如果看特定表和特定索引,您可以运行如下代码:
 

代码如下:

--Script to identify table fragmentation
--Declare variables

DECLARE
@ID int ,
@IndexID int ,
@IndexName varchar ( 128)

--Set the table and index to be examined
SELECT @IndexName = 'index_name' --enter name of index
SET @ID = OBJECT_ID ( 'table_name' ) --enter name of table

--Get the Index Values
SELECT @IndexID = IndID
FROM sysindexes
WHERE id = @ID AND name = @IndexName

--Display the fragmentation
DBCC SHOWCONTIG ( @id, @IndexID)

     结果集中最重要的参数是 Scan Density ,越接近 100% 越好。如果 Scan Density 小于 75% ,那么您可能需要重建表中的索引。
    对于小于 100 数据页,重建索引并不会有明显的性能改善。这是因为物理硬件缓存, SQL Server 缓存和 SQL Server 预读机制隐藏了碎片的负面作用。
    但对于非常大的表,重建索引会使它受益匪浅,因为涉及大量磁盘 I/O 操作。


    
 
 

您可能感兴趣的文章:

  • Sql Server 删除主键与重建主键的例子
  • SQL SEVER数据库重建索引的方法
  • 提高SQL Server性能-重建索引
  • SQL效率提升之一些SQL编写建议并有效利用索引
  • sql server对索引的使用
  • 导致SQL Server索引不可用的几种Sql语句写法
  • SQL学习笔记八 索引,表连接,子查询,ROW_NUMBER
  • SQL Server 索引结构及其使用(一)--深入浅出理解索引结构第1/4页
  • :[Microsoft][ODBC SQL Server Driver]无效的描述符索引 如何解决?
  • 提升SQL Server速度 整理索引碎片
  • sql视图创建索引的方法
  • 找出所有非xml索引并重新整理的sql
  • SQL_Server全文索引的用法解析
  • SQL Server 索引结构及其使用(二) 改善SQL语句第1/3页
  • SQL Server误区30日谈 第8天 有关对索引进行在线操作的误区
  • 优化 SQL Server 索引的小技巧
  • Sql Server 数据库索引整理语句,自动整理数据库索引
  • SQL Server全文索引服务
  • SQL_Server全文索引的使用实例演示
  • SQL Server和Oracle数据库索引介绍
  • Oracle中检查是否需要重构索引的sql
  • SQL Server 创建索引详解
  • 揭秘SQL Server 2014有哪些新特性(3)-可更新列存储聚集索引
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • SQL Server 2008如何进行数据库分离和附加详细介绍
  • 微软网站下载的Ms SQL Server2000 JDBC Driver,必须用英文版的SQL server2000吗?
  • 请问,这是什么错误!java.sql.SQLException: [Microsoft][ODBC SQL Server Driver][Named Pipes]??????? SQL Server?虽然分少,但一定给,只要您是前5名回复者中最好的以为!
  • 安装sql server 2008 management提示已安装 SQL Server 2005 Express的解决方法
  • SQL Server 2008 事件探查器(SQL SERVER Profiler) 列的说明
  • (X86/X64)安装sql server 2005 过程中提示“无法启动sql server的 启动”的解决方法
  • SQL Server降权运行 SQL Server 2000以GUESTS权限运行设置方法
  • MS SQL Server2014链接到MS SQL Server 2000的解决方案及问题处理
  • SQL语句实现SQL Server 2000及Sql Server 2005日志收缩(批量)
  • sql server不存在 sql server拒绝访问第1/3页
  • SQL Server误区30日谈 第5天 AWE在64位SQL SERVER中必须开启
  • 一定得帮我看看sql server2000通过sql server2000jdbc driver的代码
  • SQL Server统计SQL语句执行时间的脚本
  • SQL Server误区30日谈 第21天 数据损坏可以通过重启SQL Server来修复
  • SQL Server误区30日谈 第3天 即时文件初始化特性可以在SQL Server中开启和关闭
  • 创建 sql server 链接服务器的sql代码
  • jsp jdbc为什麽不能把数据insert到sql server 中,也不能从sql server中提取数据?!
  • 如何处理此错误:java.sql.SQLException: [Microsoft][ODBC SQL Server Driver]没有执行可选特性
  • sql server 2005 三个常用的小sql
  • SQL Server 中查看SQL句子执行所用的时间
  • 推荐SQL Server 重新恢复自动编号列的序号的sql代码
  • java命名空间java.sql接口statement的类成员方法: executeupdate定义及介绍
  • SQL查询分析工具 SQL Workbench/J
  • java命名空间java.sql接口connection的类成员方法: nativesql定义及介绍
  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)
  • java命名空间java.sql接口preparedstatement的类成员方法: executeupdate定义及介绍
  • SQL客户端软件 PKLite SQL Client
  • java命名空间java.sql接口rowid的类成员方法: getbytes定义及介绍
  • SQL客户端管理工具 SQuirreL SQL Client
  • java命名空间java.sql接口ref的类成员方法: getbasetypename定义及介绍
  • sql2005 大数据量检索分页的sql代码


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3