• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

第十二章SQLServer统计信息(3)发现过期统计信息并处理

mysql 搞代码 4年前 (2022-01-09) 24次浏览 已收录 0个评论

前言: 统计 信息 是关于谓词中的数据分布的主要 信息 源,如果不知道具体的数据分布,优化器不能获得预估的数据集,从而不能 统计 需要返回的数据。 在创建列的 统计 信息 后,在 DML 操作如 insert 、 update 、 delete 后, 统计 信息 就会过时。因为这些

前言:

统计信息是关于谓词中的数据分布的主要信息源,如果不知道具体的数据分布,优化器不能获得预估的数据集,从而不能统计需要返回的数据。

在创建列的统计信息后,在DML操作如insertupdatedelete后,统计信息就会过时。因为这些操作更改了数据,影响了数据分布。此时需要更新统计信息

在高活动的表中,统计信息可能几个小时就会过时。对于静态表,可能几个星期才会过时。这要视乎表上DML的操作。

2000开始,SQLServer对增删改操作会增加在表sysindexes中的RowModCtrRow Modification Counter)值,当统计信息更新后,该值会重置会0,并重新累加。所以查看这个表的这个值就可以知道统计信息是否过时。

2000之后,SQLServer改变了这种跟踪方式,把更改存放到对应的数据行上。这个值是未公开的ColModCtr

但是sys.sysindexes2012依旧可用,还是可以用这个表的数值来确定是否过期

准备工作:

本文将用到下面的系统视图和兼容性视图:

1、 sys.sysindexes:兼容性视图,提供RowModCtr列值,是本文的核心。

2、 sys.indexes:使用表ID来获得统计信息名。

3、 sys.objects:获取架构名。

步骤:

显示RowModCtr值很高的统计信息

SELECT DISTINCT        OBJECT_NAME(SI.object_id) AS Table_Name ,        SI.name AS Statis<div>本文来源gaodai^.ma#com搞#代!码网</div>tics_Name ,        STATS_DATE(SI.object_id, SI.index_id) AS Last_Stat_Update_Date ,        SSI.rowmodctr AS RowModCTR ,        SP.rows AS Total_Rows_In_Table ,        'UPDATE STATISTICS [' + SCHEMA_NAME(SO.schema_id) + '].['        + OBJECT_NAME(SI.object_id) + ']' + SPACE(2) + SI.name AS Update_Stats_ScriptFROM    sys.indexes AS SI( NOLOCK )        INNER JOIN sys.objects AS SO( NOLOCK ) ON SI.object_id = SO.object_id        INNER JOIN sys.sysindexes SSI( NOLOCK ) ON SI.object_id = SSI.id                                                    AND SI.index_id = SSI.indid        INNER JOIN sys.partitions AS SP ON SI.object_id = SP.object_idWHERE   SSI.rowmodctr > 0        AND STATS_DATE(SI.object_id, SI.index_id) IS NOT NULL        AND SO.type = 'U'ORDER BY RowModCTR DESC

分析:

需要了解一些事情:

1、 从你上次更新统计信息是何时的事情?

2、 在更新统计信息之后有多少事务发生在表上?

3、 哪些T-SQL需要用于更新统计信息

4、 更新统计信息是否可行?这个是对比RowModCTR列和Total_Rows_In_Table列。

当在数据库开启了Auto_Update_Statistics之后,还有数据的话,那就有必要更新统计信息。下面有一些规则:

1、 表大小从0增长。

2、 当表的数据小于等于500时没有问题,并且ColModCtr从超过500行之后开始增长。

3、 当表的行数超过500行时,在统计信息对象的引导列的ColModCtr值超过500+20%的行数时,就需要更新。

例子:有一个100万行的表,优化器会在插入200500行新数据后认为统计信息过时。但是这并不是绝对化的。

扩充知识:

没有直接的方式访问ColModCtr的值,因为它只是用于优化引起,并且对用户透明,但是可以使用DAC(专用管理员连接)来访问sys.sysrscols.rcmodified系统。但是仅在2008R2及以后版本才可用。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:第十二章SQLServer统计信息(3)发现过期统计信息并处理

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址