Teradata-설명

EXPLAIN 명령은 파싱 엔진의 실행 계획을 영어로 반환합니다. 다른 EXPLAIN 명령을 제외한 모든 SQL 문과 함께 사용할 수 있습니다. 쿼리 앞에 EXPLAIN 명령이 나오면 파싱 엔진의 실행 계획이 AMP 대신 사용자에게 반환됩니다.

EXPLAIN의 예

다음 정의가있는 테이블 직원을 고려하십시오.

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 );

EXPLAIN 계획의 몇 가지 예가 아래에 나와 있습니다.

전체 테이블 스캔 (FTS)

SELECT 문에 조건이 지정되지 않은 경우 옵티마이 저는 테이블의 모든 행이 액세스되는 전체 테이블 스캔을 사용하도록 선택할 수 있습니다.

다음은 최적화 프로그램이 FTS를 선택할 수있는 샘플 쿼리입니다.

EXPLAIN SELECT * FROM employee;

위 쿼리가 실행되면 다음과 같은 출력이 생성됩니다. 알 수 있듯이 옵티마이 저는 모든 AMP와 AMP 내의 모든 행에 액세스하도록 선택합니다.

1) First, we lock a distinct TDUSER."pseudo table" for read on a 
   RowHash to prevent global deadlock for TDUSER.employee.  
2) Next, we lock TDUSER.employee for read.  
3) We do an all-AMPs RETRIEVE step from TDUSER.employee by way of an
   all-rows scan with no residual conditions into Spool 1 
   (group_amps), which is built locally on the AMPs.  The size of 
   Spool 1 is estimated with low confidence to be 2 rows (116 bytes).  
   The estimated time for this step is 0.03 seconds.  
4) Finally, we send out an END TRANSACTION step to all AMPs involved 
   in processing the request. 
→ The contents of Spool 1 are sent back to the user as the result of 
   statement 1.  The total estimated time is 0.03 seconds.

고유 기본 색인

Unique Primary Index를 사용하여 행에 액세스하면 하나의 AMP 작업이됩니다.

EXPLAIN SELECT * FROM employee WHERE EmployeeNo = 101;

위 쿼리가 실행되면 다음과 같은 출력이 생성됩니다. 알 수 있듯이 단일 AMP 검색이고 옵티마이 저는 고유 한 기본 인덱스를 사용하여 행에 액세스합니다.

1) First, we do a single-AMP RETRIEVE step from TDUSER.employee by 
   way of the unique primary index "TDUSER.employee.EmployeeNo = 101" 
   with no residual conditions. The estimated time for this step is 
   0.01 seconds.  
→ The row is sent directly back to the user as the result of 
   statement 1.  The total estimated time is 0.01 seconds.

고유 한 보조 인덱스

Unique Secondary Index를 사용하여 행에 액세스하면 2 암페어 연산입니다.

다음 정의가있는 Salary 테이블을 고려하십시오.

CREATE SET TABLE SALARY,FALLBACK ( 
   EmployeeNo INTEGER, 
   Gross INTEGER, 
   Deduction INTEGER, 
   NetPay INTEGER 
)
PRIMARY INDEX ( EmployeeNo ) 
UNIQUE INDEX (EmployeeNo);

다음 SELECT 문을 고려하십시오.

EXPLAIN SELECT * FROM Salary WHERE EmployeeNo = 101;

위 쿼리가 실행되면 다음과 같은 출력이 생성됩니다. 알 수 있듯이 옵티마이 저는 고유 한 보조 인덱스를 사용하여 두 암페어 작업에서 행을 검색합니다.

1) First, we do a two-AMP RETRIEVE step from TDUSER.Salary 
   by way of unique index # 4 "TDUSER.Salary.EmployeeNo = 
   101" with no residual conditions.  The estimated time for this 
   step is 0.01 seconds.  
→ The row is sent directly back to the user as the result of 
   statement 1.  The total estimated time is 0.01 seconds.

추가 약관

다음은 EXPLAIN 계획에서 흔히 볼 수있는 용어 목록입니다.

... (Last Use) …

스풀 파일은 더 이상 필요하지 않으며이 단계가 완료되면 해제됩니다.

... with no residual conditions …

적용 가능한 모든 조건이 행에 적용되었습니다.

... END TRANSACTION …

트랜잭션 잠금이 해제되고 변경 사항이 커밋됩니다.

... eliminating duplicate rows ...

중복 행은 세트 테이블이 아닌 스풀 파일에만 존재합니다. DISTINCT 연산 수행.

... by way of a traversal of index #n extracting row ids only …

보조 인덱스 (인덱스 #n)에서 찾은 행 ID를 포함하는 스풀 파일이 빌드됩니다.

... we do a SMS (set manipulation step) …

UNION, MINUS 또는 INTERSECT 연산자를 사용하여 행 결합.

... which is redistributed by hash code to all AMPs.

조인 준비를위한 데이터 재배포.

... which is duplicated on all AMPs.

조인을 준비하기 위해 더 작은 테이블 (SPOOL 측면)에서 데이터 복제.

... (one_AMP) or (group_AMPs)

모든 AMP 대신 하나의 AMP 또는 AMP의 하위 집합이 사용됨을 나타냅니다.