SQLServer索引碎片和解决方法毫无疑问,给表添加索引是有好处的,你要做的大部分工作就是维护索引,在数据更改期间索引可能产生碎片,所以一些维护是必要的。碎片可能是你查询产生性能问题的来源。
那么到底什么是索引碎片呢?索引碎片实际上有2种形式:外部碎片和内部碎片。不管哪种碎片基本上都会影响索引内页的使用。这也许是因为页的逻辑顺序错误(即外部碎片)或每页存储的数据量少于数据页的容量(内部错误)。无论索引产生了哪种类型的碎片,你都会因为它而面临查询的性能问题。外部碎片当索引页不在逻辑顺序上时就会产生外部碎片。索引创建时,索引键按照逻辑顺序放在一组索引页上。当新数据插入索引时,新的键可能放在存在的键之间。为了让新的键按照正确的顺序插入,可能会创建新的索引页来存储需要移动的那些存在的键。这些新的索引页通常物理上不会和那些被移动的键原来所在的页相邻。创建新页的过程会引起索引页偏离逻辑顺序。下面的例子将比实际的言论更加清晰的解释这个概念。
假定在任何另外的数据插入你的表之前存在索引上的结构如下(注:下面图片里应该是7和8,原文里是6和8):INSERT语句往索引里添加新的数据,假定添加的是5。INSERT将引起新页创建,为了给5在原来的页上留出空间,7和8被移到了新页上。这个创建将引起索引页偏离逻辑顺序。在有特定搜索或者返回无序结果集的查询的情况下,偏离顺序的索引页不会引起问题。对于返回有序结果集的查询,搜索那些无序的索引页需要进行额外的处理。有序结果集的例子如查询返回4到10之间的记录。为了返回7和8,查询不得不进行额外的页切换。虽然一个额外的页切换在一个长时间运行里是无关紧要的,然而想象一下一个有好几百页偏离顺序的非常大的表的情形。内部碎片当索引页没有用到最大量时就产生了内部碎片。虽然在一个有频繁数据插入的应用程序里这也许有帮助,然而设置一个fill factor(填充因子)会在索引页上留下空间,服务器内部碎片会导致索引尺寸增加,从而在返回需要的数据时要执行额外的读操作。这些额外的读操作会降低查询的性能。怎样确定索引是否有碎片?SQLServer提供了一个数据库命令――DBCC SHOWCONTIG――来确定一个指定的表或索引是否有碎片。
DBCC SHOWCONTIG
数据库平台命令,用来显示指定的表的数据和索引的碎片信息。DBCC SHOWCONTIG权限默认授予sysadmin固定服务器角色或db_owner和db_ddladmin固定数据库角色的成员以及表的所有者且不可转让。
语法(SQLServer2000)DBCC SHOWCONTIG
[ ( { table_name | table_id| view_name | view_id }
[ , index_name | index_id ]
)
]
[ WITH { ALL_INDEXES
| FAST [ , ALL_INDEXES ]
| TABLERESULTS [ , { ALL_INDEXES } ]
[ , { FAST | ALL_LEVELS } ]
}
]语法(SQLServer7.0)DBCC SHOWCONTIG
[ ( table_id [,index_id ]
)
]示例:
显示数据库里所有索引的碎片信息
SET NOCOUNT ON
USE pubs
DBCC SHOWCONTIG WITH ALL_INDEXESGO显示指定表的所有索引的碎片信息
SET NOCOUNT ONUSE pubs
DBCC SHOWCONTIG (authors) WITH ALL_INDEXESGO显示指定索引的碎片信息
SET NOCOUNT ON
USE pubs
DBCC SHOWCONTIG (authors,aunmind)GO结果集
DBCC SHOWCONTIG将返回扫描页数、扫描扩展盘区数、遍历索引或表的页时,DBCC语句从一个扩展盘区移动到其它扩展盘区的次数、每个扩展盘区的页数、扫描密度(最佳值是指在一切都连续地链接的情况下,扩展盘区更改的理想数目)。DBCC SHOWCONTIG正在扫描'authors'表...
表: 'authors'(1977058079);
索引ID: 1,数据库ID: 5
已执行TABLE级别的扫描。
-扫描页数.....................................: 1
-扫描扩展盘区数...............................: 1
-扩展盘区开关数...............................: 0
-每个扩展盘区上的平均页数.....................: 1.0
-扫描密度[最佳值:实际值]....................: 100.00%[1:1]
-逻辑扫描碎片.................................: 0.00%
-扩展盘区扫描碎片.............................: 0.00%
-每页上的平均可用字节数.......................: 6010.0
-平均页密度(完整)...........................: 25.75%DBCC执行完毕。如果DBCC输出了错误信息,请与系统管理员联系。寻找什么扫描页数:如果你知道行的近似尺寸和表或索引里的行数,那么你可以估计出索引里的页数。看看扫描页数,如果明显比你估计的页数要高,说明存在内部碎片。扫描扩展盘区数:用扫描页数除以8,四舍五入到下一个最高值。该值应该和DBCC SHOWCONTIG返回的扫描扩展盘区数一致。如果DBCC SHOWCONTIG返回的数高,说明存在外部碎片。碎片的严重程度依赖于刚才显示的值比估计值高多少。扩展盘区开关数:该数应该等于扫描扩展盘区数减1。高了则说明有外部碎片。每个扩展盘区上的平均页数:该数是扫描页数除以扫描扩展盘区数,一般是8。小于8说明有外部碎片。扫描密度[最佳值:实际值]:DBCC SHOWCONTIG返回最有用的一个百分比。这是扩展盘区的最佳值和实际值的比率。该百分比应该尽可能靠近100%。低了则说明有外部碎片。逻辑扫描碎片:无序页的百分比。该百分比应该在0%到10%之间,高了则说明有外部碎片。扩展盘区扫描碎片:无序扩展盘区在扫描索引叶级页中所占的百分比。该百分比应该是0%,高了则说明有外部碎片。每页上的平均可用字节数:所扫描的页上的平均可用字节数。越高说明有内部碎片,不过在你用这个数字决定是否有内部碎片之前,应该考虑fill factor(填充因子)。平均页密度(完整):每页上的平均可用字节数的百分比的相反数。低的百分比说明有内部碎片。备注DBCC SHOWCONTIG实际上仅对那些大表有用。小表显示的结果根本不符合正常标准,因为他们也许没有由多于8个的页面组成。你在查看小表上执行DBCC SHOWCONTIG的结果时应该忽略一些结果。在处理小表时只需关心扩展盘区开关数、逻辑扫描碎片、每页上的平均可用字节数、平均页密度(完整)。DBCC SHOWCONTIG默认输出的结果是:扫描页数、扫描扩展盘区数、扩展盘区开关数、每个扩展盘区上的平均页数、扫描密度[最佳值:实际值]、逻辑扫描碎片、扩展盘区扫描碎片、每页上的平均可用字节数、平均页密度(完整)。可以用FAST和TABLERESULTS选项来控制这个输出结果。FAST选项指定执行索引的快速扫描,输出结果是最小的,该选项不读索引的叶或数据页且只返回扫描页数、扫描扩展盘区数、扫描密度[最佳值:实际值]、逻辑扫描碎片。TABLERESULTS选项将用行集的形式显示信息,将返回扩展盘区开关数、扫描密度[最佳值:实际值]、逻辑扫描碎片、扩展盘区扫描碎片、每页上的平均可用字节数、平均页密度(完整)。如果既指定FAST选项又指定TABLERESULTS选项,那么将返回对象名、对象ID、索引名、索引ID,页数、扩展盘区开关数、扫描密度[最佳值:实际值]和逻辑扫描碎片。ALL_INDEXES选项将显示指定表和试图的所有索引的结果,即使指定了一个索引。ALL_LEVELS选项指定是否为所处理的每个索引的每个级别产生输出(默认只输出索引的页级或表数据级的结果),并且只能与TABLERESULTS选项一起使用。解决碎片问题一旦你确定表或索引有碎片问题,那么你有4个选择去解决那些问题:1.删除并重建索引
2.使用DROP_EXISTING子句重建索引
3.执行DBCC DBREINDEX
4.执行DBCC INDEXDEFRAG
尽管每一个技术都能达到你整理索引碎片的最终目的,但各有各的优缺点。删除并重建索引用DROP INDEX和CREATE INDEX或ALTER TABLE来删除并重建索引有些缺陷包括在删除重建期间索引会消失。在索引删除重建时,对于查询它不在可用,查询性能也许会受到明显的影响,直到重建索引为止。另一个潜在的缺陷是当都请求索引的时候会引起阻塞,直到重建索引为止。通过其他的处理也能解决阻塞,就是索引被使用的时候不删除索引。另一个主要的缺陷是在用DROP INDEX和CREATE INDEX重建聚集索引时会引起非聚集索引重建两次。删除聚集索引时非聚集索引的行指针会指向数据堆,聚集索引重建时非聚集索引的行指针又会指回聚集索引的行位置。删除并重建索引的确有一个好处就是通过重新排序索引页,使索引页紧凑并删除不需要的索引页来完全重建索引。你也许需要考虑那些内部和外部碎片都很高的情况下才使用,以使那些索引回到它们应该在的位置。使用DROP_EXISTING子句重建索引为了避免在重建聚集索引时表上的非聚集索引重建两次,可以使用带DROP_EXISTING子句的CREATE INDEX语句。这个子句会保留聚集索引键值,以避免非聚集索引重建两次。和删除并重建索引一样,该方法也可能会引起阻塞和索引消失的问题。该方法的另一个缺陷是也强迫你去分别发现和修复表上的每一个索引。除了和上一个方法一样的好处之外,该方法的好处是不必重建非聚集索引两次。这样可以对那些带约束的索引提供正确的索引定义以符合约束的要求。执行DBCC DBREINDEXDBCC DBREINDEX类似于第二种方法,但它物理地重建索引,允许SQLServer给索引分配新页来减少内部和外部碎片。DBCC DBREINDEX也能动态的重建带约束的索引,不象第二种方法。DBCC DBREINDEX的缺陷是会遇到或引起阻塞问题。DBCC DBREINDEX是作为一个事务来运行的,所以如果在完成之前中断了,那么你会丢失所有已经执行过的碎片。执行DBCC INDEXDEFRAGDBCC INDEXDEFRAG(在SQLServer2000中可用)按照索引键的逻辑顺序,通过重新整理索引里存在的叶页来减少外部碎片,通过压缩索引页里的行然后删除那些由此产生的不需要的页来减少内部碎片。它不会遇到阻塞问题但它的结果没有其他几个方法彻底。这是因为DBCC INDEXDEFRAG跳过了锁定的页且不使用任何新页来重新排序索引。如果索引的碎片数量大的话你也许会发现DBCC INDEXDEFRAG比重建索引花费的时间更长。DBCC INDEXDEFRAG比其他方法的确有好处的是在其他过程访问索引时也能进行碎片整理,不会引起其他方法的阻塞问题。

【数据库】SQL Server索引碎片和解决方法相关推荐

  1. 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器(及Windows 10无法找到SQL server配置管理器的解决方法)

    这里写目录标题 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误.未找到或无法访问服务器 Windows 10无法找到SQL server配置管理器的解决方法 后续 在与 SQ ...

  2. Sql server 索引碎片

    索引碎片 数据库索引体系 数据库碎片(只讨论索引碎片) 索引碎片 内部索引碎片 外部索引碎片 索引碎片的查询 索引碎片一般解决方案 索引填充因子 数据库索引体系 要了解数据库的索引碎片,首先需要了解数 ...

  3. 需要我们了解的SQL Server阻塞原因与解决方法 - sym_cn

    2019独角兽企业重金招聘Python工程师标准>>> 这里通过连接在sysprocesses里字段值的组合来分析阻塞源头,可以把阻塞分为以下5种常见的类型(见表).waittype ...

  4. Windows10安装SQL server 2016/2014 失败解决方法( 错误代码: 0x851A0019)

    最近想学数据库,但是在安装SQL2014时总是失败,原因是  ( 错误代码: 0x851A0019)找不到数据库引擎启动句柄!网上找了很多解决方法都无效.我以为是应为Win10系统的原因,就装了SQL ...

  5. springboot连接sqlserver 驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接解决方法

    解决方法 在连接的url后面添加 ;trustServerCertificate=true 如下 spring:datasource:url: jdbc:sqlserver://localhost:1 ...

  6. 无法安装Sql Server 2000时的解决方法.

    从Google找到关于安装Sql Server 2000时发生问题的解决方法: 问:我在Windows 2000下安装Microsoft SQL Server 2000时,出现以下错误信息:A pre ...

  7. 关于Windows10无法安装SQL Server 2008的完全解决方法

    啥也不说了,先是安装SQL Server显示没有.NET Framework 3.5,安装.NET Framework 3.5时又显示无法安装,错误代码是0x80070422,在网上搜大佬们的解决方案 ...

  8. VS2010不能正确加载 'VSTS for Database Professionals Sql Server Data-tier Application'的解决方法...

    VS10出了点问题,卸载重装之后启动,弹出"VS2010不能正确加载 'VSTS for Database Professionals Sql Server Data-tier Applic ...

  9. Sql Server 2005“该用户与可信的SQL SERVER 连接无关联”解决方法

    1.在数据库实例上单击鼠标右键,选择"属性": 2.在弹出的"服务器属性"窗口中,选择"安全性": 3.在服务器身份认证模式中,选择&quo ...

最新文章

  1. 一步一步SharePoint 2007系列文章目录
  2. SQLServer中数据库的创建
  3. 学习资源之4:Linux
  4. 用户画像标签维度_神策数据钟秉哲:一文了解用户标签画像,从洞察到突破
  5. jpa jsf_完整Web应用程序Tomcat JSF Primefaces JPA Hibernate –第2部分
  6. springboot公共模块打包_SpringBoot多模块项目打包方法(jar和war)
  7. String类型直接赋值与构造赋值
  8. 问题以及发现问题和解决问题
  9. 解决:无法添加符号: DSO missing from command line
  10. 网站测试自动化系统—在测试代码中硬编码测试数据
  11. python logging打印终端_python standard package:logging
  12. Eclipse安装教程
  13. 前端传入JSON数组转换对象存入数据库
  14. win2008R2 像CA证书服务器(Linux)申请CA证书
  15. SSAO与HBAO学习笔记(持续改进)
  16. 磁共振检查头部能检测出什么_头部核磁共振可以检查什么?
  17. STO不会火,比特大陆不会死,币安会去非洲:区块链行业的63个预测
  18. 《2022元宇宙黑客松》ThreeX专场
  19. 要买还未买的书单——持续更新
  20. firefox如何卸载插件plugins和临时文件夹

热门文章

  1. 5w1h分析数据异常问题
  2. 计算机管理中可移动磁盘无内容,u盘不显示可移动磁盘-电脑插入U盘后不显示可移动磁盘,磁盘管理打不开...
  3. 谷歌的开源Python工具包fire
  4. 无线通信中,如何进行WiFi 6设备测试?
  5. 记录金蝶系统页面获取的值为Null解决办法
  6. SQL注入系列(一)——超详细SQL注入环境搭建
  7. aardio 编程语言
  8. Python 常用编程方法
  9. 闰秒是什么?ntp如何处理闰秒?
  10. 常见的思科10G光模块参数及板卡支持的光模块类型