排他プロダクト ジョイン - Teradata Database - Teradata Vantage NewSQL Engine

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

Product
Teradata Database
Teradata Vantage NewSQL Engine
Release Number
16.20
Published
2019年3月
Language
日本語
Last Update
2019-10-29
dita:mapPath
ja-JP/arh1512079329802.ditamap
dita:ditavalPath
ja-JP/arh1512079329802.ditaval
dita:id
B035-1142
Product Category
Software
Teradata Vantage

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

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

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

Teradata Databaseでは、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マージを経て、要求しているアプリケーションに送られます。

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