FIX パフォーマンス低下またはデータベースを復元して同時に SQL Server 2012年でステートメントを実行するとデッドロック

文書翻訳 文書翻訳
文書番号: 2725950 - 対象製品
Microsoft Microsoft SQL Server 2012年の修正プログラム 1 のダウンロード ファイルとして配布しています。修正プログラムは累積的であるため、各新しいリリースすべての修正プログラムが含まれているし、以前の SQL Server 2012 で含まれていたすべてのセキュリティ修正プログラム リリースを修正します。
すべて展開する | すべて折りたたむ

目次

現象

シナリオ 1

次のシナリオについて考えてみましょう:
  • Microsoft SQL Server 2012年のデータベースを復元します。
  • データベースの復元操作が完了する前に、別のプロセス、 sys.database_recovery_statusカタログ ビューを参照し、同じデータベースのロックが必要です。たとえば、次のSELECTステートメントを実行します。

    SELECT * FROM sys.database_recovery_status
このシナリオでは、データベースの復元処理が完了するまでのプロセスをSELECTステートメントを待機のパフォーマンスが低下を発生します。

シナリオ 2

次のシナリオについて考えてみましょう:
  • SQL Server 2012年のデータベースを復元します。
  • データベースの復元操作が完了する前に、次のステートメントを実行します。

    IF EXISTS (SELECT * FROM sys.database_recovery_status WHERE database_id= DataBaseID AND database_guid IS NOT NULL)
    メモ収めた データベースの復元操作を実行するデータベースの ID を表します。
このシナリオでは、データベースの復元プロセスのデッドロックを発生します。データベースの復元プロセスに失敗するとこのデッドロックが発生します。

原因

「現象」に記載されている 2 つシナリオは、同じ原因で発生します。

データベースの復元処理が、データベースに対して排他ロックを必要とするため「Scenario1」セクションでは、問題が発生します。そのセクションに記載されているステートメントを実行すると、上の同じデータベースを共有ロックが必要です。したがって、排他ロックが解放されるまで共有ロックを排他ロックは待機します。

ここでは、記載されているステートメントを実行するとは、「状況 2」のセクションでは、共有ロックは、同じデータベースとsys.sysdbregテーブルの両方に必要です。データベース復元処理の最後の段階では、更新ロック、 sys.sysdbregテーブルをプロセスする必要があります。ただし、共有ロックは、データベースからは解放されません。したがって、 sys.sysdbregテーブルには、デッドロックが発生して、データベースの復元プロセスがデッドロックの犠牲者だと判断します。

解決方法

累積的な更新プログラムの情報

SQL Server 2012年の Service Pack 1 用の累積的な更新プログラム パッケージ 1

この問題に対する修正は累積的な更新 1 でまずリリースされました。この累積的な更新プログラム パッケージを SQL Server 2012 Service Pack 1 の入手方法の詳細については、マイクロソフト サポート技術資料を参照する次の資料番号をクリックします。
2765331 SQL Server 2012年の Service Pack 1 用の累積的な更新プログラム パッケージ 1
ビルドは累積的であるため、各新しい修正プログラム リリースすべての修正プログラムが含まれているし、以前の SQL Server 2012 で含まれていたすべてのセキュリティ修正プログラム リリースを修正します。この修正プログラムを含む最新の修正プログラム リリースを適用を検討することをお勧めします。詳細については、以下の記事番号 をクリックしてマイクロソフト サポート技術情報資料を参照してください。
2772858 SQL Server 2012年の Service Pack 1 のリリース後にリリースされた、SQL Server 2012年のビルドします。

SQL Server 2012 の累積的な更新プログラム パッケージ 3

この問題に対する修正は累積的な更新プログラム 3 で最初リリースされました。この累積的な更新プログラム パッケージを SQL Server 2012 の入手方法の詳細については、マイクロソフト サポート技術資料を参照する次の資料番号をクリックします。
2723749 SQL Server 2012年の累積的な更新 3
ビルドは累積的であるため、各新しい修正プログラム リリースすべての修正プログラムが含まれているし、以前の SQL Server 2012 で含まれていたすべてのセキュリティ修正プログラム リリースを修正します。この修正プログラムを含む最新の修正プログラム リリースを適用を検討することをお勧めします。詳細については、以下の記事番号 をクリックしてマイクロソフト サポート技術情報資料を参照してください。
2692828 SQL Server 2012 のリリース後にリリースされた SQL Server 2012 のビルド

状況

マイクロソフトでは、この問題をこの資料の対象製品として記載されているマイクロソフト製品の問題として認識しています。

回避策

シナリオ 2 ではこの問題を回避するには、次の方法のいずれかを使用します。
方法 1


」として「NOLOCK ヒントを使用して、 sys.sysdbregテーブルの共有ロックを回避するステートメントを変更します。
IF EXISTS (SELECT * FROM sys.database_recovery_status with(NOLOCK) WHERE database_id= DataBaseID AND database_guid IS NOT NULL)
方法 2
ステートメントに「低」のデッドロックの優先度を設定します。
SET DEADLOCK_PRIORITY LOW
IF EXISTS(SELECT * FROM sys.database_recovery_status where database_id = DataBaseID AND database_guid IS NOT NULL)
メモステートメントと、データベースの復元プロセスのデッドロックを回避するのには、2 番目のメソッドを使用すると、IF ステートメント内のコードは実行されません。

関連情報

排他ロックの詳細については、共有ロック、更新ロックは、次の MSDN web サイトを参照してください。
ロック モードに関する一般的な情報
詳細については、増分サービス モデルについては、SQL Server は、マイクロソフト サポート技術資料を参照する次の資料番号をクリックします。
935897 報告された問題に対する修正プログラムを提供する SQL Server チームの増分サービス モデルを利用します。
名前付けスキーマを SQL Server の更新プログラムの詳細については、マイクロソフト サポート技術資料を参照する次の資料番号をクリックします。
822499 Microsoft SQL Server ソフトウェア更新プログラム パッケージの名前付けスキーマ
ソフトウェアの更新の用語の詳細については、次の資料番号をクリックし、「サポート技術情報」の記事をご覧ください。
824684 マイクロソフトのソフトウェア更新プログラムの説明に使用される一般的な用語の説明

プロパティ

文書番号: 2725950 - 最終更新日: 2012年11月20日 - リビジョン: 2.0
この資料は以下の製品について記述したものです。
  • Microsoft SQL Server 2012 Developer
  • Microsoft SQL Server 2012 Enterprise
  • Microsoft SQL Server 2012 Express
  • Microsoft SQL Server 2012 Standard
  • Microsoft SQL Server 2012 Web
キーワード:?
kbtshoot kbqfe kbfix kbsurveynew kbexpertiseadvanced kbmt KB2725950 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:2725950
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