공통 [FireDAC Skill Sprints] 6. 전처리: SQL문을 유연하게 작성할 수 있는 Param와 Macro 사용하기
2015.03.13 19:34
엠바카데로에서 FireDAC Skill Sprint 웨비나(1월 23일 ~ 3월 27일: 매주 금요일 10시)를 진행하고 있습니다.
이 글에서는 웨비나 다시보기와 함께 웨비나 일부 내용을 샘플코드와 함께 소개합니다. 하단 온라인 기술 도움말 링크를 통해 더 자세한 내용을 추가학습하시기 바랍니다.
6회차에서는 커맨드 텍스트 전처리에 관한 내용으로 진행합니다.
커맨드 텍스트 전처리란?
커맨드 텍스트 전처리는 SQL 명령을 데이터베이스에 전달하기 전 파라메터를 치환하고, FireDAC 매크로 함수를 DBMS에 맞도록 치환하는 기능입니다.
FireDAC 은 커맨드 텍스트 전처리 작업할 수 있는 3가지의 매크로 명령을 지원합니다.
- 대체변수(Substitution variables) : 파라메터 확장을 위해 SQL 문의 일부를 치환. 예를 들면 FROM절의 테이블이름과 SELECT 절의 필드명을 파라메터화 하려면 대체변수를 사용해야 함
- 이스케이프 시퀀스(Escape sequences) : 한번 작성하면 서로 다른 DBMS에서 그대로 사용할 수 있는 DBMS에 의존적이지 않은 SQL문 생성
- 조건부 대체(Conditional substitutions) : 연결된 DBMS에 따라 조건부로 실행되는 SQL 문 작성
대체변수
1 2 3 | FDQuery1 . SQL . Text := 'SELECT * FROM &TabName' ; FDQuery1 . MacroByName( 'TabName' ).AsRaw := 'Orders' ; FDQuery1 . Open; |
- 위와 같이 매크로 변수(&TabName)를 이용해 SQL 문 작성 후 MacroByName 메소드를 이용해 내용을 치환할 수 있습니다.
이스케이프 시퀀스
FireDAC은 다음 5가지 이스케이프 시퀀스가 있습니다.
- 상수 치환
- 식별자 치환
- 조건부 대체
- Like 연산자 이스케이프 시퀀스
- 스칼라 함수
그중 상수 치환 이스케이프 시퀀스를 사용하면 DBMS의 구문 및 지역설정과 관계없이 커맨드 텍스트 상수를 작성할 수 있습니다. 예를 들면 아래와 같습니다.
- {d <날짜>} : {d 2014-08-30}은 Oracle에서 TO_DATE{'2014-08-30', 'yyyy-mm-dd'} 입니다.
- {t <시간>} : {t 14:30:00}은 SQL Server에서 CONVERT (DATETIME, '14 : 30 : 00 ', 114) 입니다.(hh24:mi:ss 형식으로 작성해야 합니다.)
- {id <식별자명>} : 식별자명이 DBMS의 고유 구문으로 치환됩니다.
조건부 대체
조건부 대체는 연결된 DBMS(또는 매크로 변수 값)에 따라 명령을 대체합니다. 예를 들면 아래와 같습니다.
- {IF Oracle} TO_CHAR{fi} {IF MSSQL} CONVERT {fi} : 오라클인 경우 TO_CHAR, MSSQL인 경우 CONVERT 명령어로 실행됩니다.
❑ Preprocessing 샘플 프로그램 소개
이 샘플에서는 총 2가지 기능을 소개합니다.
테이블을 선택 후 해당 테이블의 필드를 (다중)선택 하면 매크로의 대체변수를 이용해 SQL 쿼리를 작성해 데이터를 조회합니다.
이스케이프 시퀀스를 이용해 작성한 쿼리 수행 후 FireDAC 모니터를 통해 최종적으로 실행되는 SQL 쿼리와 비교합니다.
매크로 대체변수로 필드목록과 테이블명 선택 해 데이터 조회하기
첫번째 탭에 구현된 기능으로 테이블 목록에서 테이블 선택 후 필드(다중선택) 목록에서 조회할 필드를 체크 후 "선택 데이터 표시" 버튼을 누르면 그리드에 데이터가 표시됩니다.
쿼리컴포넌트에는 아래와 같이 필드목록(&FieldList)와 대상 테이블명(&TableName)을 매크로 대체변수로 작성했습니다.
1 | SELECT &FieldList FROM &TableName |
델파이에서는 아래 코드와 같이 Macro 값을 설정하고 쿼리를 실행하면 SQL 문이 실행되기 전 필드목록과 테이블명이 치환되어 SQL 문이 실행됩니다.
1 2 3 | DM . qrySelect . MacroByName( 'FieldList' ).AsRaw := FieldList; DM . qrySelect . MacroByName( 'TableName' ).AsRaw := ListBox1 . Selected . Text; DM . qrySelect . Open; |
이스케이프 시퀀스로 DBMS 의존적이지 않은 SQL문 작성
이스케이프 시퀀스는
- FireDAC 매크로 함수를 이용해 DBMS에 의존적이지 않은 SQL문을 작성합니다.
- 매크로 함수가 포함된 SQL 문은 실행 전 DBMS에 맞는 DBMS 함수로 치환되어 SQL 문이 실행됩니다.
쿼리 컴포넌트에는 아래와 같이 매크로 함수가 포함된 SQL문을 작성했습니다.
1 2 3 | SELECT { Current_Date ()} as Today, c.* FROM &TabNam c WHERE {Extract( Year , c.SaleDate)} = {e 1988} |
애플리케이션을 실행하고 FireDAC 모니터링 기능을 이용해 처리된 SQL 문을 확인하면 아래와 같이 DBMS의 함수로 치환되어 SQL 문이 실행됩니다.
매크로 함수는 아래와 같습니다.