"エラー 8992」エラー メッセージし、一貫性のないメタデータが SQL Server のシステム カタログで

文書翻訳 文書翻訳
文書番号: 2787112 - 対象製品
すべて展開する | すべて折りたたむ

目次

現象

Microsoft SQL Server で以下の問題のいずれかが発生します。

問題 1

SQL Server データベース内のシステム テーブルを手動で更新する場合は、システム メタデータに不整合を作成することを前提としています。その後、システム メタデータ テーブル内の矛盾を識別するために、 DBCC CHECKDBコマンドを実行します。この状況では、次のエラー メッセージが返されます。
エラー 8992、レベル 16、状態 1、行 1
カタログ エラー 3853、1 の状態を確認します属性 (referenced_object_id =。オブジェクト ID>、key_index_id =インデックス ID>) 行の (object_id =オブジェクト ID>) 内の sys.foreign_keys に一致する行がない (object_id =オブジェクト ID>、index_id =インデックス ID>) sys.indexes に。

問題 2

SQL server のシステム テーブルを更新すると、次のような警告メッセージが表示されます。
警告: システム テーブルの IDテーブルの ID> はデータベース ID で直接更新されましたデータベース ID> と直接ことがありますがされて更新します。SQL Server を再起動する必要があります。
この状況では、 DBCC CHECKDBまたはDBCC CHECKCATALOGコマンドを実行すると、警告メッセージと、システム カタログが最後に変更された日時が返されます。また、次の警告メッセージは、SQL Server のログにも記録されます。
警告: システム カタログ内の ID を直接データベースに更新されました。データベース ID>、最近でログ時刻>.
メモ この情報は、データベース ヘッダーに格納されている、データベースの有効期間が続きます。

原因

この問題は、SQL Server システム テーブルの手動更新をサポートしていないために発生します。SQL Server データベース エンジンでシステム テーブルを更新する必要があります。

メモ システム カタログ ビューを使用して、システム テーブル内のデータを表示できます。

解決方法

この問題を解決するのには、次の方法のいずれかを使用します。

方法 1

クリーンなデータベースのバックアップがある場合は、バックアップからデータベースを復元します。

メモ のみバックアップ不整合にメタデータがあるない場合は、この方法を動作します。

方法 2

バックアップからデータベースを復元することはできません、データおよびオブジェクトを新しいデータベースにエクスポートします。次に、データベースの内容を手動で更新を新しいデータベースに転送します。注: 修復オプションでDBCC CHECKDBコマンドでシステム カタログ内の不整合を修復できません。コマンド メタデータの破損を修復することはできませんので、したがって、コマンド、修復が推奨されるレベルはありません。

詳細

システム カタログに行われた変更を検出、システム センターのアドバイザーのルールの詳細については、マイクロソフト サポート技術情報の資料を参照する次の資料番号をクリックします。
2688307 SQL Server データベース内のシステム テーブルを更新するとイベント ID 17659 およびイベント ID 3859 が記録される
システム カタログ内の不整合を示すエラーの例を次に示します。通常、「8992」エラー コードと共に、次のエラーが生成されます。
元に戻す全体を表示する
エラーメッセージのテキスト
3851システム テーブルの sys.%ls%ls では、無効な行 (%1!) が見つかりました
3852Sys.%ls%ls (%1!) 行に一致する行 (%ls) sys.%ls%ls ではありません。
3853属性 (%ls) 内の行 (%ls) sys.%ls%ls (%1!) の一致するローに sys.%ls%ls ではありません。
3854属性 (%ls) 内の行 (%ls) sys.%ls%ls (%1!) の一致するローが有効ではない sys.%ls%ls でがあります。
3855属性 (%1!) は sys.%ls%ls の行 (%1!) が存在します。
3856(%1!) の属性は存在しますが、いない内の行 (%ls) sys.%ls%ls する必要があります。
3857(%1!) の属性は必要ですが、sys.%ls%ls (%1!) 行がありません。
3858属性 (%ls) sys.%ls%ls (%1!) 行の値が無効です。
3859警告: システム カタログがデータベース ID %d、%s_date で最も最近に更新されました。
このような問題が発生した場合は、表示されるエラー メッセージの例を次に示します。
サーバー: メッセージ 2513年、レベル 16、状態 1、行 1
テーブル エラー: オブジェクト IDオブジェクト ID> (オブジェクト 'オブジェクト ID>') 'SYSCOLUMNS' 〜 'SYSOBJECTS' と一致しません。

3853 のメッセージ、レベル 16、状態 1、行 2
属性 (object_id =オブジェクト ID>) 行の (object_id =オブジェクト ID>、index_id =インデックス ID>) sys.indexes に一致する行がない (object_id =オブジェクト ID>) では、sys.objects。

3855 のメッセージ、レベル 16、状態 1、行 2
属性 (data_space_id = 1) に行が存在する (object_id =オブジェクト ID>、index_id =インデックス ID>) sys.indexes に。

3852 のメッセージ、レベル 16、状態 1、行 1
行 (object_id =オブジェクト ID>、index_id = 1) sys.indexes に (の種類 = U) に一致する行がない (クラス objid 0 =オブジェクト ID>、インデックス =インデックス ID>、rowsetnum = 1) sys.sysrowsetrefs で。

3852 のメッセージ、レベル 16、状態 1、行 1
行 (object_id =オブジェクト ID>、index_id = 1) sys.indexes に (の種類 = U) に一致する行がない (クラス objid 0 =オブジェクト ID>、インデックス =インデックス ID>、rowsetnum = 1) sys.sysrowsetrefs で。

3853 のメッセージ、レベル 16、状態 1、行 1
属性 (default_object_id =オブジェクト ID>) を行 (object_id =オブジェクト ID>、column_id =列の ID>) sys.columns 内に一致する行がない (object_id =オブジェクト ID>) では、sys.objects。

エラー 8992、レベル 16、状態 1、行 1
カタログ エラー 3853、1 の状態を確認します属性 (object_id =。オブジェクト ID>) 行の (object_id =オブジェクト ID>、column_id =列の ID>) sys.columns 内に一致する行がない (object_id =オブジェクト ID>) では、sys.objects。

DBCC の実行が完了しました。DBCC がエラー メッセージを出力した場合は、システム管理者に問い合わせてください。
表示されます可能性がありますまた、" CHECKDBコマンドを実行して、データベースの一貫性をチェックする場合は、次のようなエラー 211"エラー メッセージ。
211 のメッセージ、レベル 23 状態 230、行 1
スキーマが破損します。DBCC CHECKCATALOG を実行します。

メッセージ 0、レベル 20、状態 0、行 0
重大なエラーには、現在のコマンドでが発生しました。結果は破棄する必要があります。
このエラー メッセージは、システム カタログが一貫性のないメタデータが含まれていることを示します。

注: CHECKDBコマンドを実行して SQL Server 2000 からアップグレードするデータベースの整合性をチェックすると、コマンドはシステム カタログにコードとレポートの不整合」8992"エラーが返されます。この現象は、 DBCC CHECKDBコマンドで SQL Server 2000 DBCC CHECKCATALOGコマンドの機能を含んでいないために発生します。DBCC CHECKCATALOGコマンドを実行した場合を除き、これらの問題 SQL Server 2000 では検出できません。

DBCC CHECKDBコマンドを使用する方法の詳細については、次のマイクロソフト web サイトを参照してください。
DBCC CHECKDB コマンドに関する一般的な情報

関連情報

SQL Server のシステム テーブルを手動で更新する場合に発生する問題の詳細については、マイクロソフト サポート技術情報の資料を参照して文書番号をクリックします。

2688307 SQL Server データベース内のシステム テーブルを更新するとイベント ID 17659 およびイベント ID 3859 が記録される


プロパティ

文書番号: 2787112 - 最終更新日: 2013年2月4日 - リビジョン: 3.0
この資料は以下の製品について記述したものです。
  • Microsoft SQL Server 2000 Enterprise Edition
  • Microsoft SQL Server 2000 Developer Edition
  • Microsoft SQL Server 2000 Standard Edition
  • Microsoft SQL Server 2000 Workgroup Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Workgroup Edition
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Workgroup
  • Microsoft SQL Server 2008 R2 Datacenter
  • Microsoft SQL Server 2008 R2 Enterprise
  • Microsoft SQL Server 2008 R2 Developer
  • Microsoft SQL Server 2008 R2 Standard
  • Microsoft SQL Server 2008 R2 Workgroup
  • Microsoft SQL Server 2012 Enterprise
  • Microsoft SQL Server 2012 Developer
  • Microsoft SQL Server 2012 Standard
キーワード:?
kbsurveynew kbtshoot kbexpertiseadvanced kbmt KB2787112 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:2787112
Microsoft Knowledge Base の免責: Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。

フィードバック

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com