Teradata-JOIN 전략

이 장에서는 Teradata에서 사용할 수있는 다양한 JOIN 전략에 대해 설명합니다.

결합 방법

Teradata는 다양한 조인 방법을 사용하여 조인 작업을 수행합니다. 일반적으로 사용되는 조인 방법 중 일부는-

  • 결합 결합
  • 중첩 결합
  • 제품 가입

결합 결합

병합 조인 방법은 조인이 동등 조건을 기반으로 할 때 발생합니다. 병합 조인에서는 조인 행이 동일한 AMP에 있어야합니다. 행은 행 해시를 기반으로 결합됩니다. Merge Join은 다른 조인 전략을 사용하여 행을 동일한 AMP로 가져옵니다.

전략 # 1

조인 열이 해당 테이블의 기본 인덱스 인 경우 조인 행은 이미 동일한 AMP에 있습니다. 이 경우 배포가 필요하지 않습니다.

다음 직원 및 급여 테이블을 고려하십시오.

CREATE SET TABLE EMPLOYEE,FALLBACK ( 
   EmployeeNo INTEGER, 
   FirstName VARCHAR(30) , 
   LastName VARCHAR(30) , 
   DOB DATE FORMAT 'YYYY-MM-DD', 
   JoinedDate DATE FORMAT 'YYYY-MM-DD', 
   DepartmentNo BYTEINT 
) 
UNIQUE PRIMARY INDEX ( EmployeeNo );
CREATE SET TABLE Salary ( 
   EmployeeNo INTEGER, 
   Gross INTEGER,  
   Deduction INTEGER, 
   NetPay INTEGER 
) 
UNIQUE PRIMARY INDEX(EmployeeNo);

이 두 테이블이 EmployeeNo 열에서 조인되면 EmployeeNo가 조인되는 두 테이블의 기본 인덱스이므로 재배포가 발생하지 않습니다.

전략 # 2

다음 Employee 및 Department 테이블을 고려하십시오.

CREATE SET TABLE EMPLOYEE,FALLBACK (
   EmployeeNo INTEGER, 
   FirstName VARCHAR(30) , 
   LastName VARCHAR(30) , 
   DOB DATE FORMAT 'YYYY-MM-DD', 
   JoinedDate DATE FORMAT 'YYYY-MM-DD', 
   DepartmentNo BYTEINT 
) 
UNIQUE PRIMARY INDEX ( EmployeeNo );
CREATE SET TABLE DEPARTMENT,FALLBACK ( 
   DepartmentNo BYTEINT, 
   DepartmentName CHAR(15) 
) 
UNIQUE PRIMARY INDEX ( DepartmentNo );

이 두 테이블이 DeparmentNo 열에서 조인되는 경우 DepartmentNo는 한 테이블의 기본 인덱스이고 다른 테이블의 기본이 아닌 인덱스이므로 행을 재분배해야합니다. 이 시나리오에서 조인 행은 동일한 AMP에 있지 않을 수 있습니다. 이 경우 Teradata는 DepartmentNo 열에 직원 테이블을 재배포 할 수 있습니다.

전략 # 3

위의 Employee 및 Department 테이블의 경우 Teradata는 Department 테이블의 크기가 작은 경우 모든 AMP에서 Department 테이블을 복제 할 수 있습니다.

중첩 결합

Nested Join은 모든 AMP를 사용하지 않습니다. 중첩 조인이 발생하려면 조건 중 하나가 한 테이블의 고유 기본 인덱스에서 동일해야하며이 열을 다른 테이블의 인덱스에 조인해야합니다.

이 시나리오에서 시스템은 한 테이블의 고유 기본 인덱스를 사용하여 한 행을 가져오고 해당 행 해시를 사용하여 다른 테이블에서 일치하는 레코드를 가져옵니다. 중첩 조인은 모든 조인 방법 중에서 가장 효율적입니다.

제품 가입

Product Join은 한 테이블의 각 한정 행을 다른 테이블의 각 한정 행과 비교합니다. 제품 결합은 다음 요인 중 일부로 인해 발생할 수 있습니다.

  • 조건이없는 곳.
  • 조인 조건은 동등 조건을 기반으로하지 않습니다.
  • 테이블 별칭이 올바르지 않습니다.
  • 다중 결합 조건.