Teradata-MultiLoad
MultiLoad는 한 번에 여러 테이블을로드 할 수 있으며 INSERT, DELETE, UPDATE 및 UPSERT와 같은 다양한 유형의 작업을 수행 할 수도 있습니다. 한 번에 최대 5 개의 테이블을로드하고 스크립트에서 최대 20 개의 DML 작업을 수행 할 수 있습니다. MultiLoad에는 대상 테이블이 필요하지 않습니다.
MultiLoad는 두 가지 모드를 지원합니다-
- IMPORT
- DELETE
MultiLoad에는 대상 테이블 외에 작업 테이블, 로그 테이블 및 두 개의 오류 테이블이 필요합니다.
Log Table − 다시 시작하는 데 사용될로드 중에 취해진 체크 포인트를 유지하는 데 사용됩니다.
Error Tables−이 테이블은 오류 발생시로드 중에 삽입됩니다. 첫 번째 오류 테이블은 변환 오류를 저장하고 두 번째 오류 테이블은 중복 레코드를 저장합니다.
Log Table − 재시작을 위해 MultiLoad 각 단계의 결과를 유지합니다.
Work table− MultiLoad 스크립트는 대상 테이블 당 하나의 작업 테이블을 생성합니다. 작업 테이블은 DML 작업과 입력 데이터를 유지하는 데 사용됩니다.
한정
MultiLoad에는 몇 가지 제한 사항이 있습니다.
- 대상 테이블에서 고유 한 보조 인덱스가 지원되지 않습니다.
- 참조 무결성이 지원되지 않습니다.
- 트리거는 지원되지 않습니다.
MultiLoad의 작동 원리
MultiLoad 가져 오기에는 5 단계가 있습니다.
Phase 1 − 예비 단계 – 기본 설정 작업을 수행합니다.
Phase 2 − DML 트랜잭션 단계 – DML 문의 구문을 확인하고 Teradata 시스템으로 가져옵니다.
Phase 3 − 획득 단계 – 입력 데이터를 작업 테이블로 가져오고 테이블을 잠급니다.
Phase 4 − 적용 단계 – 모든 DML 작업을 적용합니다.
Phase 5 − 정리 단계 – 테이블 잠금을 해제합니다.
MultiLoad 스크립트에 관련된 단계는 다음과 같습니다.
Step 1 − 로그 테이블을 설정합니다.
Step 2 − Teradata에 로그온합니다.
Step 3 − 목표, 작업 및 오류 테이블을 지정합니다.
Step 4 − INPUT 파일 레이아웃을 정의합니다.
Step 5 − DML 쿼리를 정의합니다.
Step 6 − IMPORT 파일의 이름을 지정합니다.
Step 7 − 사용할 LAYOUT을 지정합니다.
Step 8 −로드를 시작합니다.
Step 9 −로드를 완료하고 세션을 종료합니다.
예
다음 레코드로 텍스트 파일을 만들고 파일 이름을 employee.txt로 지정합니다.
101,Mike,James,1980-01-05,2010-03-01,1
102,Robert,Williams,1983-03-05,2010-09-01,1
103,Peter,Paul,1983-04-01,2009-02-12,2
104,Alex,Stuart,1984-11-06,2014-01-01,2
105,Robert,James,1984-12-01,2015-03-09,3
다음 예제는 직원 테이블에서 레코드를 읽고 Employee_Stg 테이블로로드하는 MultiLoad 스크립트입니다.
.LOGTABLE tduser.Employee_log;
.LOGON 192.168.1.102/dbc,dbc;
.BEGIN MLOAD TABLES Employee_Stg;
.LAYOUT Employee;
.FIELD in_EmployeeNo * VARCHAR(10);
.FIELD in_FirstName * VARCHAR(30);
.FIELD in_LastName * VARCHAR(30);
.FIELD in_BirthDate * VARCHAR(10);
.FIELD in_JoinedDate * VARCHAR(10);
.FIELD in_DepartmentNo * VARCHAR(02);
.DML LABEL EmpLabel;
INSERT INTO Employee_Stg (
EmployeeNo,
FirstName,
LastName,
BirthDate,
JoinedDate,
DepartmentNo
)
VALUES (
:in_EmployeeNo,
:in_FirstName,
:in_Lastname,
:in_BirthDate,
:in_JoinedDate,
:in_DepartmentNo
);
.IMPORT INFILE employee.txt
FORMAT VARTEXT ','
LAYOUT Employee
APPLY EmpLabel;
.END MLOAD;
LOGOFF;
MultiLoad 스크립트 실행
입력 파일 employee.txt가 생성되고 멀티로드 스크립트의 이름이 EmployeeLoad.ml로 지정되면 UNIX 및 Windows에서 다음 명령을 사용하여 멀티로드 스크립트를 실행할 수 있습니다.
Multiload < EmployeeLoad.ml;