FIX クエリのコンパイル済みプランのメモリ使用量が予期せず SQL Server 2005 の増加します。

文書翻訳 文書翻訳
文書番号: 919636
# をバグ: 810 (SQL 修正プログラム)
Notice
Microsoft Microsoft SQL Server 2005年修正プログラム 1 つのダウンロード ファイルとして配布しています。修正プログラムは累積的であるため、各新しいリリースすべての修正プログラムが含まれているし、以前の SQL Server 2005 に含まれていたすべてのセキュリティ修正プログラム リリースを修正します。
すべて展開する | すべて折りたたむ
ここにはこの修正プログラムのリリースに関する次について説明します。
  • この修正プログラム パッケージで修正される問題
  • この修正プログラム パッケージをインストールするための必要条件
  • この修正プログラム パッケージをインストールした後、コンピューターを再起動する必要があるかどうかについて
  • 修正プログラム パッケージが他の修正プログラム パッケージによって置き換えられますかどうかに関する情報
  • レジストリの変更が必要かどうかに関する情報
  • この修正プログラム パッケージに含まれているファイル

現象

クエリのコンパイル済みのクエリ プランを確認すると、SQL Server Microsoft SQL Server 2000 に比較 2005 について、コンパイル済みのクエリ プランのメモリ使用量が予期せず増加可能性があることがあります。

この問題は、次の条件のいずれかに該当する場合に発生します。
  • 条件 1: クエリは、計算列を使用するテーブルを参照します。
  • 条件 2: クエリには文字列の操作間の値にはが含まれています。 nvarchar 列および ANSI 文字列。たとえば、文字列操作の値を比較します。 nvarchar ANSI 文字列の列。
  • 条件 3: クエリに計算列を持つテーブルへの参照が含まれています。計算列がに基づいて、 nvarchar 列です。ただし、[コンピューター] 列を式の中で ANSI 文字列定数を使用します。
条件 2 と 3 で、コンパイルされたクエリ プランのメモリ使用量は大幅に増加が生じます。

たとえば、テーブルがある、 nvarchar 列です。MyTable テーブル名をされますと、 nvarchar 列名は MyCol. です。その後、次の構文を使用してクエリを定義します。
SELECT CASE MyCol
          WHEN 'Value1' THEN 'NewValue1'
          WHEN 'Value2' THEN 'NewValue2'
          ELSE MyCol
       END
FROM MyTable
この例では、"Value1"、"Value2"、「新しい値 1」、および"NewValue2"の文字列は ANSI 文字列です。MyCol の値 nvarchar 列"Value1"、"Value2"、ANSI 文字列を比較先。次に、対応する値の新しい値を「1」、"NewValue2"が、ANSI 文字列または MyCol 列の元の値を選択します。

調べることで、コンパイル済みプランのメモリ使用量を表示できます、 pagesused sys.syscacheobjects システム テーブルは、sys.dm_exec_cached_plans 動的管理ビューの列。

サイズについて、コンパイル済みのクエリ プランを向上も、待機時間の増加 RESOURCE_SEMAPHORE_QUERY_COMPILE の待機のタイプの可能性があります。

解決方法

サポートされている修正プログラムがマイクロソフトから入手可能です。ただし、この修正プログラムはこの資料に記載されている問題のみを修正するものです。この修正プログラムはこの問題が発生しているシステムにのみ適用されます。この修正プログラムは、今後さらにテストを受け取ることがあります。したがって、この問題で深刻な影響をされていない場合は、この修正プログラムを含む次のソフトウェア更新プログラムのリリースを待つことをお勧めします。

この修正プログラムがダウンロードできないか場合は、この記事の上部に「修正プログラムのダウンロード」セクションです。このセクションが表示されない場合は、マイクロソフト カスタマー サービス & サポート修正プログラムを入手するに問い合わせてください。

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

前提条件

SQL Server 2005 サービス パック インストールこの修正プログラムを適用する 1 (SP1) が必要です。 SQL Server 2005 Service Pack 1 の入手方法の詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
913089SQL Server 2005 の最新の service pack を入手する方法

情報を再起動します。

この修正プログラムを適用した後コンピューターを再起動するはありません。ただしで既にこの問題が発生した場合は、データベース ファイルが正常な状態に戻すには、この修正プログラムを適用すると"Workground"のセクションの手順に従ってください。

レジストリ情報

レジストリを変更するはありません。

修正プログラムのファイル情報

この修正プログラムにはこの資料に記載されている問題を修正するために必要なファイルのみが含まれています。この修正プログラムは、製品を最新のビルドに更新するために必要なすべてのファイルの含めることはできません。

この修正プログラムの英語版がファイル属性 (またはそれ以降のファイル属性) が、次のとおり。日付および時刻これらのファイルを世界協定時刻 (UTC) が表示されます。ファイル情報を表示すると、ローカル時刻に変換します。UTC とローカル時刻との時差を確認するを使用して、 タイム ゾーン コントロール パネルの日付と時刻の項目に含まれる ◇
SQL Server 2005 の 32年ビット バージョン
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Microsoft.sqlserver.sqlenum.dll9.0.2164.0908,0642006 年 6 月 14 日12: 32x 86
Microsoft.sqlserver.mgdsqldumper.dll2005.90.2164.075,5522006 年 6 月 14 日12: 29x 86
Msgprox.dll2005.90.2164.0197,9202006 年 6 月 14 日12: 29x 86
Replprov.dll2005.90.2164.0547,6162006 年 6 月 14 日12: 31x 86
Replrec.dll2005.90.2164.0782,1122006 年 6 月 14 日12: 32x 86
Msmdlocal.dll9.0.2164.015,661,8562006 年 6 月 14 日12: 33x 86
Sqlaccess.dll2005.90.2164.0347,9362006 年 6 月 14 日12: 31x 86
Sqlservr.exe2005.90.2164.028,950,8722006 年 6 月 14 日12: 33x 86
SQL Server 2005 x 64 ベース版
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Microsoft.sqlserver.sqlenum.dll9.0.2164.0875,2962006 年 6 月 14 日13: 12x 86
Microsoft.sqlserver.mgdsqldumper.dll2005.90.2164.091,4242006 年 6 月 14 日12: 29x64
Msgprox.dll2005.90.2164.0259,3602006 年 6 月 14 日13: 10x64
Replprov.dll2005.90.2164.0745,2482006 年 6 月 14 日13: 12x64
Replrec.dll2005.90.2164.01,008,4162006 年 6 月 14 日13: 12x64
Msmdlocal.dll9.0.2164.015,661,8562006 年 6 月 14 日12: 33x 86
Sqlaccess.dll2005.90.2164.0355,1042006 年 6 月 14 日13: 11x 86
Sqlservr.exe2005.90.2164.039,251,2322006 年 6 月 14 日13: 13x64
SQL Server 2005 の Itanium アーキテクチャ バージョン
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Microsoft.sqlserver.sqlenum.dll9.0.2164.0875,2962006 年 6 月 14 日12: 29x 86
Microsoft.sqlserver.mgdsqldumper.dll2005.90.2164.0163,1042006 年 6 月 14 日12: 29IA-64
Msgprox.dll2005.90.2164.0542,4962006 年 6 月 14 日12: 28IA-64
Msmdlocal.dll9.0.2164.048,733,9842006 年 6 月 14 日12: 30IA-64
Replprov.dll2005.90.2164.01,617,1842006 年 6 月 14 日12: 29IA-64
Replrec.dll2005.90.2164.02,141,4722006 年 6 月 14 日12: 29IA-64
Sqlaccess.dll2005.90.2164.0349,4722006 年 6 月 14 日12: 28x 86
Sqlservr.exe2005.90.2164.072,208,6722006 年 6 月 14 日12: 30IA-64

回避策

この問題を回避するには、問題のコンテキスト内のすべての文字列の前に大文字のアルファベット"N"に追加します。「現象」セクション次構文を使用して記載されている例を変更できます。 します

SELECT CASE MyCol WHEN N'Value1' THEN N'NewValue1' WHEN N'Value2' THEN N'NewValue2' ELSE MyCol END FROM MyTable

状況

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

詳細

調べることで、コンパイル済みプランのメモリ使用量を表示できます、 pagesused sys.syscacheobjects システム テーブルは、sys.dm_exec_cached_plans 動的管理ビューの列。

Sys.syscacheobjects システム ・ テーブルの詳細については、次のマイクロソフト開発ネットワーク (MSDN) Web サイトを参照してください。
http://msdn2.microsoft.com/en-us/library/ms187815.aspx
Sys.dm_exec_cached_plans 動的管理ビューの詳細については、次の MSDN Web サイトを参照してください。
http://msdn.microsoft.com/en-us/library/ms187404.aspx
Microsoft SQL Server 更新プログラムの名前付けスキーマの詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
822499Microsoft SQL Server のソフトウェア更新プログラム パッケージの新しい命名方式は
ソフトウェアの更新の用語の詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
824684マイクロソフトのソフトウェア更新プログラムの説明に使用される一般的な用語の説明

プロパティ

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