FIX SQL Server 上のテーブルに挿入する SELECT ステートメントを実行すると 2008 年エラー メッセージ:「'<primarykey>' の主キー制約の違反です。重複するキーを挿入できません '<tablename>'"</tablename></primarykey>

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

目次

現象

次のシナリオを検討してください。
  • Microsoft SQL Server 2008 が、マルチプロセッサのコンピューターにインストールがあります。
  • しては、 選択を挿入します。 ステートメント上の主キーを含むテーブルです。

    メモ で、 選択を挿入します。 ステートメントは、データを受け取るテーブル、データ出力は同じテーブルです。たとえば。
    INSERT T1 … SELECT T1
  • 他のテーブルでこれを参照します。 選択を挿入します。 ステートメントです。これらの参照には、一時テーブルが含まれます。

    メモ テーブルで参照されている、 から 句、またはテーブルがサブクエリまたは結合条件で参照できます。
ステートメントを実行すると、次のエラー メッセージが表示されます。

メッセージ 2627年、レベル 14、状態 1
主キー制約の違反が '主キー'.重複するキーを挿入できません 'テーブル名'.

実行プランを調べるが判明、 結合 演算子とは、 熱心なスプール 同時に実行する演算子です。これ 熱心なスプール 演算子の下では、 結合 演算子です。また、内のステートメントがデータを受信するテーブルは結合の内部テーブルです。

メモ この問題は、実行時にも発生、 更新の選択 ステートメントまたは 選択の削除します。 ステートメントです。

原因

この問題は発生のスプールのバグのため、 熱心なスプール 演算子は、スプールが予想よりも多くの行を生成します。この現象は、重複するキーの問題が発生します。

解決方法

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

この問題に対する修正は SQL Server 2008 Service Pack 1 の累積的な更新プログラム 3 で初めてリリースされました。この累積的な更新プログラム パッケージの詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
971491 SQL Server 2008 Service Pack 1 用の累積的な更新パッケージ 3
メモ ビルドは累積的であるため、各新しい修正プログラム リリースにはすべての修正プログラムが含まれています、以前の SQL Server 2008 に含まれていたすべてのセキュリティ修正プログラム リリースを修正します。マイクロソフトはこの修正プログラムを含む最新の修正プログラム リリースを適用を検討することをお勧めします。詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
970365 SQL Server の 2008 SQL Server 2008 Service Pack 1 のリリース後にリリースされたビルドします。
Microsoft SQL Server 2008 SQL Server サービス ・ パックの特定の修正プログラムが作成されます。SQL Server 2008 Service Pack 1 をインストールする SQL Server 2008 Service Pack 1 の修正プログラムを適用する必要があります。既定では、SQL Server サービス パックで提供されている修正プログラム SQL Server の次の service pack に含まれてです。

修正プログラムの情報

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

この問題を解決するには、マイクロソフト カスタマー サポート サービス、修正プログラムを入手するに問い合わせてください。Microsoft カスタマー サポート サービスの電話番号とサポート コストに関する情報の完全な一覧については、次のマイクロソフト Web サイトを参照してください。
http://support.microsoft.com/contactus/?ws=support
メモ Microsoft Support 担当者が特定の更新で問題が解決されると判断した場合は特殊なケースでは、料金が通常のサポート免除されるキャンセルする可能性があります。追加の質問および問題の特定のアップデートの対象とならない問題、通常のサポート料金が適用されます。

前提条件

この修正プログラムを適用するには、SQL Server 2008 Service Pack 1 (SP1) を実行してコンピューターする必要があります。

情報を再起動します。

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

レジストリ情報

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

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

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

この修正プログラムの英語版がファイル属性 (またはそれ以降のファイル属性) が、次のとおり。日付および時刻これらのファイルを世界協定時刻 (UTC) が表示されます。ファイル情報を表示すると、ローカル時刻に変換します。UTC とローカル時刻との時差を確認するを使用して、 タイム ゾーン タブには 日付と時刻 コントロール パネルの項目。
サポートされているすべての SQL Server 2008年データベース エンジンの x86 ベースのバージョン x
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Sqlaccess.dll2007.100.2712.0405,35213-月-200917: 53x 86
Keyfile.dll2007.100.2712.013,65613-月-200915: 37x 86
Sqlservr.exe2007.100.2712.042,729,32013-月-200917: 56x 86
サポートされているすべての SQL Server 2008年の分析サービスの x86 ベースのバージョン x
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Msmdlocal.dll10.0.2712.023,461,72013-月-200916: 08x 86
Msmdsrv.exe10.0.2712.021,955,41613-月-200916: 09x 86
Keyfile.dll2007.100.2712.013,65613-月-200915: 37x 86
Msmdpump.dll10.0.2712.06,180,69613-月-200916: 08x 86
Msmdspdm.dll10.0.2712.0178,00813-月-200916: 08x 86
Msmgdsrv.dll10.0.2712.08,558,93613-月-200916: 09x 86
Msolap100.dll10.0.2712.06,532,95213-月-200916: 09x 86
サポートされているすべての SQL Server 2008年データベース エンジンの x64 ベース バージョン x
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Sqlaccess.dll2007.100.2712.0412,00814-月-200901: 15x 86
Keyfile.dll2007.100.2712.014,18413-月-200923: 55x64
Sqlservr.exe2007.100.2712.057,873,25614-月-200901: 17x64
サポートされているすべての SQL Server 2008年の分析サービスの x64 ベース バージョン x
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Msmdlocal.dll10.0.2712.023,461,72013-月-200916: 08x 86
Msmdlocal.dll10.0.2712.044,436,82414-月-200900: 10x64
Msmdsrv.exe10.0.2712.043,713,36814-月-200900: 10x64
Keyfile.dll2007.100.2712.014,18413-月-200923: 55x64
Msmdpump.dll10.0.2712.07,430,48814-月-200900: 10x64
Msmdspdm.dll10.0.2712.0178,02414-月-200900: 10x 86
Msmgdsrv.dll10.0.2712.08,558,93613-月-200916: 09x 86
Msmgdsrv.dll10.0.2712.012,332,37614-月-200900: 11x64
Msolap100.dll10.0.2712.06,532,95213-月-200916: 09x 86
Msolap100.dll10.0.2712.08,153,94414-月-200900: 11x64
すべての Itanium ベース バージョン SQL Server 2008年データベース エンジンのサポート
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Sqlaccess.dll2007.100.2712.0398,69613-月-200917: 01x 86
Keyfile.dll2007.100.2712.019,30413-月-200915: 26IA-64
Sqlservr.exe2007.100.2712.0111,042,40813-月-200917: 08IA-64
Itanium ベースのバージョンの SQL Server 2008年の分析サービスのサポートされているすべての
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間プラットフォーム
Msmdlocal.dll10.0.2712.023,461,72013-月-200916: 08x 86
Msmdlocal.dll10.0.2712.057,508,18413-月-200915: 44IA-64
Msmdsrv.exe10.0.2712.058,860,88813-月-200915: 46IA-64
Keyfile.dll2007.100.2712.019,30413-月-200915: 26IA-64
Msmdpump.dll10.0.2712.08,943,44813-月-200915: 45IA-64
Msmdspdm.dll10.0.2712.0178,00813-月-200915: 45x 86
Msmgdsrv.dll10.0.2712.015,485,80013-月-200915: 47IA-64
Msmgdsrv.dll10.0.2712.08,558,93613-月-200916: 09x 86
Msolap100.dll10.0.2712.010,065,24013-月-200915: 47IA-64
Msolap100.dll10.0.2712.06,532,95213-月-200916: 09x 86

回避策

この問題を回避するには、MAXDOP クエリ ヒントまたは MAXDOP オプションを設定します。 1 ステートメントまたはサーバー レベルでは。

メモ サーバー レベル MAXDOP オプションは、サーバー上で実行するすべてのクエリのパフォーマンスに影響します。

状況

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

関連情報

SQL Server の増分サービス モデルの詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
935897報告された問題に対する修正プログラムを提供するのには、SQL Server チームの増分サービス モデルを利用します。


SQL Server 更新プログラムの名前付けスキーマの詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
822499Microsoft SQL Server のソフトウェア更新プログラム パッケージの新しい命名方式は


ソフトウェアの更新の用語の詳細については、Knowledge Base の資料を参照するのには、次の資料番号をクリックしてください。
824684 マイクロソフトのソフトウェア更新プログラムの説明に使用される一般的な用語の説明

プロパティ

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