1.索引碎片
1.1什么是索引碎片?
由于表上有过度地插入、修改和删除操作,索引页被分成多块就形成了索引碎片,如果索引碎片严重,那扫描索引的时间就会变长,甚至导致索引不可用,因此数据检索操作就慢
下来了。
有两种类型的索引碎片:内部碎片和外部碎片。
内部碎片:
为了有效的利用内存,使内存产生更少的碎片,要对内存分页,内存以页为单位来使用,最后一页往往装不满,于是形成了内部碎片。
外部碎片:为了共享要分段,在段的换入换出时形成外部碎片,比如5K的段换出后,有一个4k的段进来放到原来5k的地方,于是形成1k的外部碎片。
查询碎片的情况:
(1) dbcc showcontig:四部分对象名,【索引名】|【索引id】
(2) dbcc showcontig:当前库对象id,【索引名】|【索引id】
(3) sys.dm_db_index_physical_stats:数据库id,对象id,索引id,分区id,扫描模式 ‘
显示数据库里所有索引的碎片信息时,代码如下:
SET NOCOUNT ONUSE pubsDBCC SHOWCONTIG WITH ALL_INDEXESGO
显示指定表的所有索引的碎片信息时,代码如下:
SET NOCOUNT ONUSE pubsDBCC SHOWCONTIG (authors) WITH ALL_INDEXESGO
2.计划缓存
计划缓存会大大减少执行计划的编译,从而提高效率。
Select * FROM sys.dm_exec_cached_plans
我们可以通过以上代码找到被缓存的执行计划。
被缓存的执行计划所存储的内容非常丰富,不仅仅包括被缓存的执行计划、语句,还包括被缓存执行计划的统计信息,比如说CPU的使用、等待时间等。
3.统计信息
sqlserver是根据表中的统计信息进行行数估计,按照脚本语义来确定物理操作步骤生成执行计划,再按照该执行计划访问数据。表和视图都有统计信息,统计信息对象是根据索引或表列的列表创建的。当某列第一次最为条件查询时,将创建单列的统计信息。当创建索引时,将创建同名的统计信息。索引中,统计信息只统计首列,因此索引除了按首列排序存储数据外,其统计信息也是按首列计算统计的,所以索引设置时定义的第一列非常重要。每个统计信息对象都在包含一个或多个表列的列表上创建,并且包括显示值在第一列中的分布的直方图。