엠바카데로에서 FireDAC Skill Sprint 웨비나(1월 23일 ~ 3월 27일: 매주 금요일 10시)를 진행하고 있습니다.
이 글에서는 웨비나 다시보기와 함께 웨비나 일부 내용을 샘플코드와 함께 소개합니다. 하단 온라인 기술 도움말 링크를 통해 더 자세한 내용을 추가학습하시기 바랍니다.
9회차에서는 쿼리 결과에서 검색하고, 조인할 수 있는 Local SQL에 대해 알아봅니다.
Local SQL이란?
Local SQL은 DB로부터 애플리케이션의 메모리 상으로 가져온 데이터(데이터셋: TDataSet을 상속받은 객체)를 대상으로 다시 SQL 쿼리를 할 수 있는 기능입니다.
Local SQL은 아래와 같이 사용할 수 있습니다.
- 여러 이기종 DB들에 대한 쿼리 : 다양한 DB에서 가져온 여러 데이터셋을 대상으로 원하는 데이터 쿼리(조인 가능)
- 인 메모리 데이터베이스 : TFDMemTable은 메모리상에 있는 데이터셋의 역할
- 오프라인 모드 쿼리 : 원격 DB에 연결할 수 없는 경우에도, 이미 가져온 데이터셋을 대상으로 쿼리 실행
- 데이터스냅 클라이언트 쿼리 : 데이터스냅 서버(미들웨어)에서 받아온 데이터셋을 대상으로 쿼리 실행
- 간편한 마이그레이션 : 애플리케이션 내에서 써드파티를 통해 가져온 데이터셋 객체를 대상으로 쿼리 실행
용어> 데이터셋(DataSet) = 애플리케이션의 메모리 상에 있는 데이터 집합
Local SQL 사용을 위한 FireDAC 컴포넌트 구성
- TFDConnection의 DriverName을 SQLite로 설정합니다.(FireDAC의 Local SQL 엔진으로 SQLite 드라이버를 사용합니다.)
- TFDLocalSQL과 TFDQuery 컴포넌트의 Connection을 위의 TFDConnection으로 설정
- TFDLocalSQL 컴포넌트의 DataSets 컬랙션(속성)에 조회할 데이터셋(TDataSet을 상속받은 객체)을 등록
Local SQL의 설정의 자세한 내용은 엠바카데로 기술문서 - Local SQL (FireDAC) 페이지를 참고하시기 바랍니다.
Local SQL 샘플 프로그램
샘플 프로그램에서는 TFDLocalSQL 컴포넌트를 이용해 5가지의 서로 다른 유형의 데이터셋에서 필요한 데이터만 조회해 그리드에 표시합니다.
[샘플코드는 http://delphi.org/2015/03/firedac-local-sql/에서 받을 수 있습니다.]
샘플에서 중점적으로 확인할 내용
- 총 5 종류의 서로다른 데이터를 대상으로 쿼리
- dbExpress : dbExpress를 이용해 데이터베이스에서 가져온 데이터
- REST CDS : REST Client를 이용해 웹서비스에서 가져온 데이터
- IBX : IBX를 이용해 인터베이스 DB에서 가져온 데이터
- MemTable from Code : 코드로 직접 만든 로컬 데이터
- ADO & Access : ADO 기술을 이용해 엑세스 DB에서 가져온 데이터
- FDLocalSQL1의 DataSets 컬랙션에는 5개의 데이터셋을 검색 대상으로 등록
- FDQuery1에서는 FDLocalSQL1.DataSets에 등록된 데이터셋 대상으로 SQL 쿼리를 작성해 검색할 수 있습니다.
SELECT sales.order_status, customers.customer, regions.RegionDescription, rest.name as REP FROM rest INNER JOIN RestSalesReps ON rest.id = RestSalesReps.RestID INNER JOIN Sales ON RestSalesReps.Sales_Rep = Sales.Sales_REP INNER JOIN customers ON sales.cust_no = customers.cust_no LEFT OUTER JOIN regions ON regions.RegionID = RestSalesReps.RestID