Teradata-매크로

매크로는 매크로 이름을 호출하여 저장 및 실행되는 SQL 문 집합입니다. 매크로의 정의는 데이터 사전에 저장됩니다. 사용자는 매크로를 실행하기 위해 EXEC 권한 만 필요합니다. 사용자는 매크로 내에서 사용되는 데이터베이스 개체에 대한 별도의 권한이 필요하지 않습니다. 매크로 문은 단일 트랜잭션으로 실행됩니다. 매크로의 SQL 문 중 하나가 실패하면 모든 명령문이 롤백됩니다. 매크로는 매개 변수를 받아 들일 수 있습니다. 매크로는 DDL 문을 포함 할 수 있지만 매크로의 마지막 문이어야합니다.

매크로 만들기

매크로는 CREATE MACRO 문을 사용하여 생성됩니다.

통사론

다음은 CREATE MACRO 명령의 일반 구문입니다.

CREATE MACRO <macroname> [(parameter1, parameter2,...)] ( 
   <sql statements> 
);

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

직원 아니요 이름 생일
101 마이크 제임스 1980 년 1 월 5 일
104 알렉스 스튜어트 1984 년 11 월 6 일
102 로버트 윌리엄스 1983 년 3 월 5 일
105 로버트 제임스 1984 년 12 월 1 일
103 베드로 1983 년 4 월 1 일

다음 예제에서는 Get_Emp라는 매크로를 만듭니다. 여기에는 직원 테이블에서 레코드를 검색하는 select 문이 포함되어 있습니다.

CREATE MACRO Get_Emp AS ( 
   SELECT 
   EmployeeNo, 
   FirstName, 
   LastName 
   FROM  
   employee 
   ORDER BY EmployeeNo; 
);

매크로 실행

매크로는 EXEC 명령을 사용하여 실행됩니다.

통사론

다음은 EXECUTE MACRO 명령의 구문입니다.

EXEC <macroname>;

다음 예제는 매크로 이름 Get_Emp를 실행합니다. 다음 명령을 실행하면 직원 테이블에서 모든 레코드를 검색합니다.

EXEC Get_Emp; 
*** Query completed. 5 rows found. 3 columns returned. 
*** Total elapsed time was 1 second.  
EmployeeNo             FirstName                      LastName 
-----------  ------------------------------  --------------------------- 
   101                  Mike                          James 
   102                  Robert                        Williams 
   103                  Peter                         Paul 
   104                  Alex                          Stuart 
   105                  Robert                        James

매개 변수화 된 매크로

Teradata 매크로는 매개 변수를 허용 할 수 있습니다. 매크로 내에서 이러한 매개 변수는; (세미콜론).

다음은 매개 변수를 허용하는 매크로의 예입니다.

CREATE MACRO Get_Emp_Salary(EmployeeNo INTEGER) AS ( 
   SELECT 
   EmployeeNo, 
   NetPay 
   FROM  
   Salary 
   WHERE EmployeeNo = :EmployeeNo; 
);

매개 변수화 된 매크로 실행

매크로는 EXEC 명령을 사용하여 실행됩니다. 매크로를 실행하려면 EXEC 권한이 필요합니다.

통사론

다음은 EXECUTE MACRO 문의 구문입니다.

EXEC <macroname>(value);

다음 예제는 매크로 이름 Get_Emp를 실행합니다. 매개 변수로 직원 번호를 받아들이고 해당 직원에 대한 직원 테이블에서 레코드를 추출합니다.

EXEC Get_Emp_Salary(101); 
*** Query completed. One row found. 2 columns returned. 
*** Total elapsed time was 1 second.
 
EmployeeNo      NetPay 
-----------  ------------ 
   101           36000