排他プロダクト ジョイン - Advanced SQL Engine - Teradata Database

Teradata Vantage™ - SQLリクエストおよびトランザクション処理

Product
Advanced SQL Engine
Teradata Database
Release Number
17.10
Published
2021年7月
Language
日本語
Last Update
2021-09-23
dita:mapPath
ja-JP/uqf1592445067244.ditamap
dita:ditavalPath
ja-JP/wrg1590696035526.ditaval
dita:id
B035-1142
Product Category
Software
Teradata Vantage

排他プロダクト ジョインのプロセス

  1. 左のテーブルの行ごとに、右のテーブルのすべての行をそれに結合できるものが見つかるまで最初から読み取ります。
  2. 結合結果を作成します。

    右のテーブルの一致する行が見つからない場合、左の行に戻ります。

Vantageでは、8バイト パーティション化の排他プロダクト ジョインについて、動的行パーティション排除をサポートしていません。

排他プロダクト ジョインの例

次のリクエストは、シカゴに勤務していない従業員の名前を返します。

SELECT name
FROM employee
WHERE dept_no NOT IN (SELECT dept_no
                      FROM department
                      WHERE loc = ’CHI’);

Subquery が1行のみを返すため、最適化ルーチンは、次のプロセスを使用して結合計画に排他プロダクト ジョインを選択します。

  1. loc = ‘CHI’であるdepartment行が、すべてのAMPで探索されます。
    • 1つのAMPだけが選択された場合、locがインデックスである場合には、全AMP検索は実行されません。
    • 単一のdepartment行が含まれているスプールは、スプールされたemployee行のあるすべてのAMPにコピーされます。
  2. この条件、department 600を満たす単一の行が見つかると、ローカルAMPでスプールしないで、直ちにコピーされます。
  3. 各AMPで、2つのスプール内の行が排他プロダクト ジョインされます。
  4. 各AMPで、600以外のdept_noを持ったemployee行のName情報が結果スプールに入れられます。
  5. 最後のAMPが結合のその部分を完了したときに、すべての結果スプールの内容が、BYNETマージを経て、要求しているアプリケーションに送られます。

次の図は、このプロセスを示したものです。


排他プロダクト ジョインの例