博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
学习笔记:索引碎片、计划缓存、统计信息
阅读量:6418 次
发布时间:2019-06-23

本文共 1059 字,大约阅读时间需要 3 分钟。

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是根据表中的统计信息进行行数估计,按照脚本语义来确定物理操作步骤生成执行计划,再按照该执行计划访问数据。表和视图都有统计信息,统计信息对象是根据索引或表列的列表创建的。当某列第一次最为条件查询时,将创建单列的统计信息。当创建索引时,将创建同名的统计信息。索引中,统计信息只统计首列,因此索引除了按首列排序存储数据外,其统计信息也是按首列计算统计的,所以索引设置时定义的第一列非常重要。每个统计信息对象都在包含一个或多个表列的列表上创建,并且包括显示值在第一列中的分布的直方图。

转载于:https://www.cnblogs.com/caiduncheng/p/8029783.html

你可能感兴趣的文章
比原空投问答题库题解(二)
查看>>
闪烁的LED灯
查看>>
MySQL Proxy 实现MySQLDB 读写分离
查看>>
ef core 数据迁移命令
查看>>
dedecms--二次开发之会员帐号过期无法登录
查看>>
四则运算
查看>>
uva 10269(floyd+Dijkstra)
查看>>
Codeforces Round #230 (Div. 1) 解题报告
查看>>
WCF 中wsHttpBinding配置实例程序
查看>>
Android Matrix
查看>>
438. Find All Anagrams in a String - Easy
查看>>
vue路由的优化
查看>>
C++ 运算符重载
查看>>
myclipse里有感叹号的问题,希望可以帮到各位
查看>>
OneZero第四周第二次站立会议(2016.4.12)
查看>>
iphone 如何获取iphone的硬件版本以及系统信息
查看>>
回收站参数介绍
查看>>
读书笔记
查看>>
node.js之内存机制特性
查看>>
bzoj3355[Usaco2004 Jan]有序奶牛*
查看>>