如何检测过期的统计信息(转)
在大多數情況下,人為更新統計信息可以獲得更好的性能。這個文章,我們可以來看下如何檢測過期的統計信息。
在SQL Server 2005以后的版本里,SQL Server使用ColModCtr?對統計的主要列對象進行跟蹤。但在?SQL server 2005或SQL server 2008里沒有對應的DMV進行查詢,直到SQL server 2008 R2 (SP2)?開始的版本,才有sys.dm_db_stats_properties?對統計的主要列對象改變有詳細的統計信息。
對于老版本的SQL Server用戶來說,我們需要基于sys.sysindexes的可用rowmodctr。自SQL Server 2005開始的版本,rowmodctr已經與老版本不再兼容。在SQL Server早期版本里,數據庫引擎維護行級別的計數器修改(row-level modification counters)。這些計數器現在在列級別維護。因此,rowmodctr用來計算和生成的結果與早期版本的計數器類似,但不完全等同。
下面的查詢可以列出在統計信息里的預估改變:?
SELECT
TableName=OBJECT_NAME(i.OBJECT_ID)
,ObjectType=o.type_desc
,StatisticsName=i.[name]
,statisticsUpdateDate = STATS_DATE(i.OBJECT_ID, i.index_id)
,RecordModified=si.rowmodctr
,NumberofRecords=si.rowcnt
FROM sys.indexes i
JOIN sys.objects o ON i.OBJECT_ID=o.OBJECT_ID
JOIN sys.sysindexes si ON i.OBJECT_ID=si.id
AND i.index_id=si.indid
WHERE o.TYPE <> 'S' AND STATS_DATE(i.OBJECT_ID, i.index_id) IS NOT NULL
UNION ALL
SELECT
TableName=OBJECT_NAME(o.OBJECT_ID)
,ObjectType=o.type_desc
,StatisticsName=s.name
,statisticsUpdateDate= STATS_DATE(o.OBJECT_ID, s.stats_id)
,RecordModified=si.rowmodctr
,NumberofRecords=ir.rowcnt
FROM sys.stats s INNER JOIN sys.objects o ON s.OBJECT_ID=o.OBJECT_ID
JOIN sys.sysindexes si ON s.OBJECT_ID=si.id AND s.stats_id= si.indid
INNER JOIN (SELECT id,rowcnt FROM sys.sysindexes WHERE indid IN (0,1)) IR
ON IR.id=o.OBJECT_ID WHERE o.TYPE <> 'S'
AND (s.auto_created=1 OR s.user_created=1)AND STATS_DATE(o.OBJECT_ID, s.stats_id) IS NOT NULL
根據這個查詢結果,加上我們系統中現運行查詢的工作量/類別,我們就可以在合適的時間用計劃任務定期對統計信息進行更新,不用盲目的更新所有統計信息。
總結
以上是生活随笔為你收集整理的如何检测过期的统计信息(转)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第二次冲刺------第三天
- 下一篇: 7、ReadWriteLock