Tsqlを使用して、DBCC checkdbがSQLサーバー(2000、2005、または2008)で最後に実行されたのはいつかを知るにはどうすればよいですか?
よろしく
Tsqlを使用して、DBCC checkdbがSQLサーバー(2000、2005、または2008)で最後に実行されたのはいつかを知るにはどうすればよいですか?
よろしく
2005年以降は実行できます
DBCC DBINFO ('YourDatabaseName') WITH TABLERESULTS
dbi_dbccLastKnownGoodを探します
これを試して、SQL2005以降のすべてのDBを確認してください
SET NOCOUNT ON;
DBCC TRACEON (3604);
CREATE TABLE #temp (
Id INT IDENTITY(1,1),
ParentObject VARCHAR(255),
[Object] VARCHAR(255),
Field VARCHAR(255),
[Value] VARCHAR(255)
)
CREATE TABLE #Results (
DBName VARCHAR(255),
LastGoodDBCC VARCHAR(255)
)
DECLARE @Name VARCHAR(255);
DECLARE looping_cursor CURSOR
FOR
SELECT name
FROM master.dbo.sysdatabases
WHERE CONVERT(varchar(500),databasepropertyex(name, 'Status'),0) = 'ONLINE'
OPEN looping_cursor
FETCH NEXT FROM looping_cursor INTO @Name
WHILE @@FETCH_STATUS = 0
BEGIN
INSERT INTO #temp
EXECUTE('DBCC PAGE (['+@Name+'], 1, 9, 3)WITH TABLERESULTS');
INSERT INTO #Results
SELECT @Name,MAX(VALUE) FROM #temp
WHERE Field = 'dbi_dbccLastKnownGood';
FETCH NEXT FROM looping_cursor INTO @Name
END
CLOSE looping_cursor;
DEALLOCATE looping_cursor;
SELECT DBName
,ISNULL(LastGoodDBCC,'1900-01-01 00:00:00.000') AS 'LastGoodDBCC'
FROM #Results
DROP TABLE #temp
DROP TABLE #Results
DBCC TRACEON (3604);
GO
-- page 9 is the boot page
DBCC PAGE (dbname, 1, 9, 3);
GO
dbi_dbccLastKnownGoodフィールドを探す必要があります。DBCC CHECKDBが破損を検出せずに実行されたのは、これが最後でした。
SQL Server 2016 SP2以降では、次のものを使用できます。
SELECT DATABASEPROPERTYEX(DB_NAME(), 'LastGoodCheckDbTime')
LastGoodCheckDbTime
指定されたデータベースで最後に正常に実行されたDBCCCHECKDBの日時。
NULL =入力が無効ですベースデータ型:datetime
#tempテーブルがカーソル内で切り捨てられないため、上記のクエリは誤った結果を生成します
SET NOCOUNT ON;
DBCC TRACEON (3604);
CREATE TABLE #temp (
Id INT IDENTITY(1,1),
ParentObject VARCHAR(255),
[Object] VARCHAR(255),
Field VARCHAR(255),
[Value] VARCHAR(255)
)
CREATE TABLE #Results (
DBName VARCHAR(255),
LastGoodDBCC VARCHAR(255)
)
DECLARE @Name VARCHAR(255);
DECLARE looping_cursor CURSOR
FOR
SELECT name
FROM master.dbo.sysdatabases
WHERE CONVERT(varchar(500),databasepropertyex(name, 'Status'),0) = 'ONLINE'
OPEN looping_cursor
FETCH NEXT FROM looping_cursor INTO @Name
WHILE @@FETCH_STATUS = 0
BEGIN
INSERT INTO #temp
EXECUTE('DBCC PAGE (['+@Name+'], 1, 9, 3)WITH TABLERESULTS');
INSERT INTO #Results
SELECT @Name,MAX(VALUE) FROM #temp
WHERE Field = 'dbi_dbccLastKnownGood';
truncate table #temp
FETCH NEXT FROM looping_cursor INTO @Name
END
CLOSE looping_cursor;
DEALLOCATE looping_cursor;
SELECT DBName
,ISNULL(LastGoodDBCC,'1900-01-01 00:00:00.000') AS 'LastGoodDBCC'
FROM #Results
Ola Hallengrenのメンテナンススクリプトを使用する場合、この情報はCommandLog
テーブルに保存されます。以下は、先週からすべてのDBCC_CHECKDB実行を取得する方法です。
USE [master]
GO
SELECT *
FROM [CommandLog]
WHERE [CommandType] ='DBCC_CHECKDB'
AND (CONVERT([datetime], [StartTime], 102) >= GETDATE() - 7)
ORDER BY [StartTime], [EndTime]