修正: SQL Server 2008 SQL Server 2008年の R2 または SQL Server 2012年に SQL Server 2005 からのアップグレード後は、sp_cursoropen ストアド プロシージャは、クエリを実行するとパフォーマンスが低下する可能性があります。

文書翻訳 文書翻訳
文書番号: 2649913
すべて展開する | すべて折りたたむ

目次

マイクロソフト Microsoft SQL Server 2008 R2 Service Pack 1 (SP1) で配布または Microsoft SQL Server 2012年で 1 つのダウンロード可能なファイルが修正されます。修正プログラムは累積的であるため、各新しいリリースすべての修正プログラムが含まれているし、以前 SQL Server 2008 R2 Service Pack 1 (SP1) または Microsoft SQL Server 2012年に含まれていたすべてのセキュリティ更新プログラムのリリースを更新します。

現象

次のシナリオを検討してください:
  • Microsoft SQL Server 2005 から 2008 の Microsoft SQL Server または Microsoft SQL Server 2008 R2 または Microsoft SQL Server 2012年にアップグレードします。
  • 使用するクエリを実行、 sp_cursoropen ストアド プロシージャ、および、指定の 行数 テーブルの最初のいくつかの行をフェッチするパラメーターを指定します。
このシナリオでは、パフォーマンスを SQL Server 2005 では、同じクエリを実行する場合よりも低速な場合があります。

原因

この問題は、動的カーソルのプランのではなく静的カーソル プラン、クエリ オプティマイザーを使用するために発生します。静的カーソル プラン、SQL Server のすべての行をフェッチし、カーソルの作業テーブルに挿入されます。ただし、動的カーソル プランは、SQL Server ののために必要な行のみをフェッチします。

解決方法

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

SQL Server 2012

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

SQL Server 2008年の R2 SP1 用の累積的な更新プログラム パッケージ 5

この修正プログラムを適用した後、トレース フラグ 4199 を有効にします。

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

回避策

この問題を回避するには、クエリ ヒントをクエリに追加します。

詳細

クエリ ヒントの使用方法の詳細については、次の MSDN web サイトを参照してください。
クエリ ヒントの使用方法に関する一般的な情報
トレース フラグ 4199 の詳細については、次の web サイトを参照してください。
トレース フラグ 4199 に関する一般的な情報

状況

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

プロパティ

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