FIX: 多数のテーブル変数では、SQL Server 2008 R2 または SQL Server 2008 のテーブル値関数を使用するとパフォーマンスが低下

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

目次

現象

Microsoft SQL Server 2008 R2 または Microsoft SQL Server 2008年でテーブル値関数で、テーブルの多くの変数を使用することを前提としています。この状況では、 sys.sysmultiobjrefs[2:1:103]データベース内のテーブルがTempdbの競合が発生します。サービス プロファイル識別子の待機は、 PAGELATCH_EXまたはPAGELATCH_SHsys.sysmultiobjrefsテーブルにサイズの大きいブロックの連鎖をラッチ型を待機します。

原因

この問題は、オブジェクトの依存関係を処理する内部関数がロックされ、ほとんどの場合、行はありませんが、次のローを削除ために発生します。したがって、排他ページ ラッチの多く発生します。

解決方法

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

SQL Server 2008 Service Pack 3 用の累積的な更新 10

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

SQL Server 2008 R2 Service Pack 1

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

SQL Server 2008 R2

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

修正プログラムの情報

サポートされている修正プログラムをマイクロソフトから入手することができます。ただし、この修正プログラムはこの資料に記載されている問題のみを修正するものです。この修正プログラムはこの問題が発生しているシステムにのみ適用して下さい。

修正プログラムがダウンロード可能な場合は、この記事の上部に「修正プログラムのダウンロード」セクションが表示されます。このセクションが表示されない場合は、マイクロソフト カスタマー サービスへリクエストを送信して、修正プログラムを入手してください。

その他の問題が発生した場合、またはトラブルシューティングが必要な場合は、別のサービス リクエストを作成する必要があります。追加の質問およびこの特定の修正プログラムの対象とならない問題については、通常のサポート料金が適用されます。一覧マイクロソフト カスタマー サービス & サポートの電話番号のまたは別のサービス リクエストを作成するには、次のマイクロソフト web サイトを参照してください。
http://support.microsoft.com/contactus/?ws=support
「修正プログラムのダウンロード」フォームには、修正プログラムを利用可能な言語が表示されます。お使いの言語が見つからない場合は、修正プログラムがその言語で利用可能ではありません。

前提条件

この修正プログラムを適用するのには、SQL Server 2008 R2 または SQL Server 2008 のインストールが必要です。

再起動の必要性

この修正プログラムを適用した後、コンピューターを再起動する必要があります。

修正プログラムの置き換えに関する情報

この修正プログラムは、以前にリリースされた修正プログラムを置き換えません。

ファイル情報

この修正プログラムのグローバル バージョンがファイル属性 (またはそれ以降のファイル属性) が、次の表に一覧表示されます。これらのファイルの日付と時刻は世界協定時刻 (UTC) で表示されます。ファイルの情報を表示するはローカル時刻に変換されます。UTC とローカル時刻との時差を確認するのを使用して、 タイム ゾーン タブには 日付と時刻 コントロール パネルの項目。

SQL Server 2008 のファイル情報
元に戻す全体を表示する
ファイル名ファイル バージョンファイル サイズ日付時間プラットフォーム
Sqlservr.exe2007.100.5831.043,080,70425-1 月-201315:14x86
Sqlservr.exe2007.100.5831.058,131,45625-1 月-201315:16x64
Sqlservr.exe2007.100.5831.0111,902,20025-1 月-201315:14IA-64

SQL Server 2008 R2 のファイル情報
元に戻す全体を表示する
ファイル名ファイル バージョンファイル サイズ日付時間プラットフォーム
Sqlservr.exe2009.100.1798.0122,301,79216-6 月-201122:19x86
Sqlservr.exe2009.100.1798.061,978,46416-6 月-201122:53x64
Sqlservr.exe2009.100.1798.042,910,56016-6 月-201123:50IA-64

回避策

この問題を回避するには、次の方法のいずれかを使用します。
  • 無効にします。 AUTO_UPDATE_STATISTICS Microsoft SQL Server 2008 R2 Management Studio のオプションです。
  • 動的テーブル値関数を削除します。

状況

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

詳細

ユーザー定義のテーブル値関数の詳細については、次の MSDN web サイトを参照してください。
テーブル値ユーザー定義関数に関する一般的な情報


プロパティ

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