現在オフラインです。再接続するためにインターネットの接続を待っています

FIX、CROSS APPLY 句を使用して、SQL Server 2008 R2 または SQL Server 2012年で FULL JOIN のクエリを実行すると誤った結果

重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。

英語版 KB:2800797
Microsoft Microsoft SQL Server 2008 R2 Service Pack 2 (SP2) の修正は 1 つのダウンロード ファイルとして配布しています。修正プログラムは累積的なあるため各新しいリリースにはすべての修正プログラムが含まれていて、以前 SQL Server 2008 R2 Service Pack 2 に含まれていたすべてのセキュリティ修正プログラム リリースを修正します。
現象
次の条件に該当する場合、クエリでは、Microsoft SQL Server 2008 R2 SP2 または Microsoft SQL Server 2012年の実行すると誤った結果が表示されます。
  • クエリは、 CROSS APPLYFULL JOIN句の結果を使用します。
  • FULL JOIN句では、テーブル値ユーザー定義関数を呼び出すことによって、テーブルのデータが提供されます。
  • 関数は、列名をパラメーターとして受け入れるし、結果をテーブルとして返します。
たとえば、次のようなクエリを実行します。
SELECT * FROM tablename CROSS APPLY (    SELECT * FROM        (SELECT * FROM [dbo].[func_GetTableFromXml](xmlColumn) WHERE nodeParentName = 'New') s1     FULL JOIN         (SELECT * FROM [dbo].[func_GetTableFromXml](xmlColumn) WHERE nodeParentName = 'Old') s2     ON s1.nodeName = s2.nodeName    ) s 
メモ この問題を Microsoft SQL Server 2012 では発生しません。
解決方法

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

累積的な更新プログラム 7 の SQL Server 2012

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

SQL Server 2012年の SP1 用の累積的な更新 3

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

SQL Server 2008 R2 の SP2 の累積的な更新 5

この問題に対する修正は累積的な更新 5 にまずリリースされました。この累積的な更新プログラム パッケージを SQL Server 2008 R2 SP 2 を取得する方法の詳細については、マイクロソフト サポート技術情報の資料を参照する次の資料番号をクリックします。
2797460 SQL Server 2008 R2 Service Pack 2 用の累積的な更新プログラム パッケージ 5
ビルドは累積的であるため、各新しい修正プログラム リリースすべての修正プログラムが含まれているし、以前 SQL Server 2008 R2 SP 2 に含まれていたすべてのセキュリティ修正プログラム リリースを修正します。この修正プログラムが含まれている最新の修正プログラム リリースを適用を検討することをお勧めします。詳細については、以下の記事番号をクリックして、マイクロソフト サポート技術情報資料を参照してください。
2730301 SQL Server 2008 R2 Service Pack 2 のリリース後にリリースされた SQL Server 2008 R2 を作成します。
状況
マイクロソフトでは、この問題をこの資料の「対象製品」として記載されているマイクロソフト製品の問題として認識しています。
回避策
この問題を回避するには、 FULL JOIN句ではなく、完全マージ JOIN句を使用します。

たとえば、クエリは次のようなもので、「現象」に記載されているクエリを変更します。
SELECT * FROM tablename CROSS APPLY (    SELECT * FROM        (SELECT * FROM [dbo].[func_GetTableFromXml](xmlColumn) WHERE nodeParentName = 'New') s1     FULL MERGE JOIN         (SELECT * FROM [dbo].[func_GetTableFromXml](xmlColumn) WHERE nodeParentName = 'Old') s2     ON s1.nodeName = s2.nodeName    ) s
詳細
CROSS APPLY句の使用方法の詳細については、次のマイクロソフト TechNet web サイトを参照してください。

警告: この記事は自動翻訳されています

プロパティ

文書番号:2800797 - 最終更新日: 04/15/2013 12:17:00 - リビジョン: 3.0

Microsoft SQL Server 2008 R2 Service Pack 2, Microsoft SQL Server 2008 R2 Datacenter, Microsoft SQL Server 2008 R2 Enterprise, Microsoft SQL Server 2008 R2 Developer, Microsoft SQL Server 2008 R2 Standard, Microsoft SQL Server 2008 R2 Web, Microsoft SQL Server 2008 R2 Workgroup, Microsoft SQL Server 2008 R2 Express, 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, SQL Server 2012 Enterprise Core

  • kbqfe kbfix kbsurveynew kbexpertiseadvanced kbmt KB2800797 KbMtja
フィードバック