次の方法で共有


MSSQLSERVER_8992

適用対象: SQL サーバー

詳細

Item 先頭値
製品名 SQL Server
イベント ID 8992
イベント ソース MSSQLSERVER
コンポーネント SQLEngine
シンボル名 DBCC3_CHECK_CATALOG
メッセージ テキスト カタログ メッセージ ERROR Level LEVEL の確認、状態 STATE: MESSAGE

Note

8992 エラー メッセージでは、実際の不整合に関する別の特定のメッセージ (3851 から 3858 まで) が参照されます。

説明

DBCC CHECKCATALOG または DBCC CHECKDB により、指定されたオブジェクトの不整合がシステム メタデータ テーブルで検出されました。 つまり、記録されたオブジェクト ID とエラー メッセージで指定されたオブジェクトの間に不整合があります。

このエラーは、システム メタデータに不整合が生じるような方法で 1 つ以上のシステム テーブルを手動で更新した場合に発生することがあります。 たとえば、ユーザーが他のテーブルにある関連する行 (sysindexessyscolumns など) を削除せずに、sysobjects テーブルからオブジェクトを手動で削除した可能性があります。

このエラーは、SQL Server 2000 から SQL Server 2005 以降にアップグレードされたデータベースに対して DBCC CHECKDB を実行しているときに発生することがあります。 SQL Server 2000 では、DBCC CHECKDB に DBCC CHECKCATALOG 機能がありませんでした。そのため、SQL Server 2000 のデータベースに対して DBCC CHECKCATALOG を指定して実行しない限り、アップグレード前にこのエラーはキャッチされません。

エラー 8992 と共に、次のいずれかのエラーが表示される場合があります。

メッセージ ID メッセージ テキスト
3851 システム テーブル sys.%ls%ls に無効な行 (%ls) が見つかりました。
3852 sys.%ls%ls の行 (%ls) と一致する行 (%ls) が sys.%ls%ls にありません。
3853 sys.%ls%ls の行 (%ls) の属性 (%ls) には、sys.%ls%ls に一致する行 (%ls) がありません。
3854 sys.%ls%ls の行 (%ls) の属性 (%ls) には、sys.%ls%ls に一致する行 (%ls) がありますが、無効です。
3855 属性 (%ls) が存在しますが、sys.%ls%ls の行 (%ls) がありません。
3856 属性 (%ls) が存在しますが、sys.%ls%ls の行 (%ls) では使用できません。
3857 属性 (%ls) が必要ですが、sys.%ls%ls の行 (%ls) にはありません。
3858 sys.%ls%ls の行 (%ls) の属性 (%ls) には、無効な値が含まれています。

ユーザーの操作

指定されたオブジェクトを削除して再作成する

可能であれば、指定されたオブジェクトを削除して再作成します。 たとえば、オブジェクトがストアド プロシージャまたはユーザー定義型である場合、オブジェクトを再作成することで問題が解決する可能性があります。

バックアップから復元する

問題がハードウェアに関するものではなく、また既知のクリーン バックアップがある場合は、そのバックアップを使用してデータベースを復元します。 この操作は、バックアップにメタデータ エラーが含まれていない場合にのみ実行できます。

新しいデータベースにデータをエクスポートする

また、バックアップにメタデータの不整合が含まれている場合は、新しいデータベースを作成し、作成したデータベースに既存のデータベースのコンテンツをエクスポートする必要があります。

DBCC CHECKDB でこのエラーを修復できない

このエラーを修正することはできません。 バックアップからデータベースを復元できない場合は、マイクロソフト カスタマー サポート サービス (CSS) にご連絡ください。

システム テーブルを手動で更新しない

システム テーブルは手動で更新しないでください。 SQL Server では、システム テーブルを手動で変更することはサポートされていません。 SQL Server データベース内のシステム テーブルを更新すると、次のイベントがログに記録されます。

システム テーブルが手動で更新された場合

メッセージ 17659: 警告: システム テーブル ID <id> がデータベース ID <id> で直接更新され、キャッシュの一貫性が維持されていない可能性があります。 SQL Server を再起動してください。

手動で更新されたシステム テーブルを使用してデータベースを開始する

メッセージ 3859: 警告: システム カタログがデータベース ID <id> で直接更新されました(最近ではdate_time

システム テーブルが手動で更新された後に DBCC_CHECKDB コマンドを実行する場合

メッセージ 3859: 警告: システム カタログは、データベース ID <id> (最近では date_time) で直接更新されました。

参照

システム ベース テーブル