엠바카데로에서 FireDAC Skill Sprint 웨비나(1월 23일 ~ 3월 27일: 매주 금요일 10시)를 진행하고 있습니다.


이 글에서는 웨비나 다시보기와 함께 웨비나 일부 내용을 샘플코드와 함께 소개합니다. 하단 온라인 기술 도움말 링크를 통해 더 자세한 내용을 추가학습하시기 바랍니다.


5회차에서는 FireDAC의 캐스캐이딩 옵션에 대해 소개하고 살펴봅니다.

FireDAC 캐스캐이딩 옵션

FireDAC에는 5종류의 옵션 그룹을 제공합니다.

  • FetchOptions : DBMS에서 데이터를 어떻게 취득할지 제어하는 검색 옵션입니다.
  • FormatOptions : DBMS의 데이터형식을 FireDAC 데이터 형식으로 또는 반대로 매핑하는 방법을 제어하는 형식 옵션입니다.(자세한 내용은 "Data Type Mapping"을 참조하세요.)
  • UpdateOptions : DBMS에 업데이트 전송 방법을 제어하는 업데이트 옵션입니다. 업데이트 시 테이블의 모든 필드를 업데이트하거나 변경된 필드만 업데이트 할 수 있습니다.
  • ResourceOptions : 시스템 리소스 사용과 데이터셋의 지속성을 제어하는 자원 옵션입니다. 예를 들면 FireDAC Phys 레이어 명령을 비동기 적으로 실행 또는 차단할 수 있습니다.
  • TxOptions : 트랜젝션 실행방법을 제어하는 트랜젝션 옵션입니다. 


위의 옵션은 Manager > Connection > DataSet/Command로 캐스캐이딩(위에서 아래로 적용) 됩니다. 즉, TFDConnection에 옵션을 설정하면 해당 연결을 사용하는 TFDQuery, TFDTable도 동일한 옵션이 적용됩니다.(일부 옵션 제외)

FireDAC 카테고리 별 주요옵션

다음은 FireDAC 주요옵션을 카테고리별로 나열한 것입니다. 각 옵션에 대한 자세한 내용은 항목 아래 기술문서 링크에 방문해 상세 설명을 보시기 바랍니다.


검색옵션(FetchOptions)

  • 취득 방법 ( CursorKind , Mode , RowsetSize ). 예를 들어, 결과 세트의 모든 레코드를 한 번에 검색 할 수 주문형 레코드를 검색 할 수 있습니다. 
  • 자원 보존 방법 ( Unidirectional , AutoClose , Cache , AutoFetchAll ). 
  • BLOB 필드 중첩 된 레코드 메타 데이터 검색 및 캐시 방법 ( Items , Cache ). 
  • 마스터/디테일 데이터셋 관계의 처리 방법 ( DetailDelay , DetailOptimize , DetailCascade ). 
  • 행 집합 페이징 ( RecsMax , RecsSkip ). 
  • TFDTable 작동 모드 ( CursorKind , LiveWindowParanoic , LiveWindowFastFirst ). 
  • 데이터 집합의 레코드를 세는 방법 ( RecordCountMode ).

TFDFetchOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDFetchOptions


형식옵션(FormatOptions)

  • 문자열 데이터 형식 ( StrsEmpty2Null , StrsTrim , StrsTrim2Len , InlineDataSize , MaxStringSize ) 
  • 숫자 데이터 형식 ( MaxBcdPrecision , MaxBcdScale , Round2Scale ) 
  • 시간 데이터 형식 ( Round2Scale ) 
  • 일반적인 데이터 형식 매핑 ( MapRules , OwnMapRules , DefaultParamDataType ). 예를 들어 NUMERIC (9, 0)의 열을 ftInteger 컬럼에 맵핑 할 수 있습니다. 
  • 필드 형식 ( FmtDisplayDateTime , FmtDisplayDate , FmtDisplayTime , FmtDisplayNumeric , FmtEditNumeric ) 
  • 데이터 집합의 정렬 ( SortLocale , SortOptions ) 
  • 식별자 따옴표 ( QuoteIdentifiers )

TFDFormatOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDFormatOptions


업데이트옵션(UpdateOptions)

  • 데이터 편집 허용 ( EnableDelete , EnableInsert , EnableUpdate , ReadOnly , CheckRequired , CheckReadOnly , CheckUpdatable ). 여기에는 TField.ReadOnly 과 TField.Required 도 영향을줍니다. 
  • 데이터베이스 레코드 잠금 ( LockMode , LockPoint , LockWait ). 
  • 자동 증가 필드에 대한 데이터베이스 생성기와 시퀀스의 사용 ( FetchGeneratorsPoint , GeneratorName ). 여기에는 TField.AutoGenerateValue 도 영향을줍니다. 
  • 업데이트 사후 명령의 생성 ( UpdateChangedFields , UpdateNonBaseFields , UpdateMode , FastUpdates ). 여기에는 TField.ProviderFlags 과 TField.Origin 도 영향을줍니다. 
  • 데이터의 업데이트 ( RefreshMode , RefreshDelete ). 
  • 업데이트 포스트 결과 확인 ( CountUpdatedRecords ).

TFDUpdateOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDUpdateOptions


리소스옵션(ResourceOptions)

  • SQL 명령 텍스트 전처리 ( EscapeExpand , MacroCreate , MacroExpand , ParamCreate , ParamExpand , PreprocessCmdText , UnifyParams ). 
  • 명령의 준비 ( DirectExecute , DefaultParamType ). 
  • 명령 실행 ( CmdExecMode , CmdExecTimeout , ArrayDMLSize ). 
  • 자원 관리 ( SilentMode ). 
  • 데이터 집합 지속성 ( Persistent , Backup , BackupExt , BackupFolder , DefaultStoreExt , DefaultStoreFolder , DefaultStoreFormat , StoreVersion , StoreItems ).

TFDResourceOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDResourceOptions


트랜젝션옵션(TxOptions)

  • 독점적 수준 ( Isolation ) 
  • 업데이트 기능 ( ReadOnly ) 
  • 자동 커밋 ( AutoCommit , AutoStart , AutoStop , StopOptions ) 
  • DBMS 고유의 파라미터 ( Params ) 
  • 액션 연결 해제 ( DisconnectAction ) 중첩 ( EnableNested )

TFDTxOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDTxOptions

FireDAC 옵션 샘플프로그램

이 샘플에서는 FetchOptions을 이용해 아래 3가지 기능을 구현했습니다.

  • 테이블에 데이터가 많은 경우 신속하게 화면에 표시하기 위해 데이터를 나눠서 가져오기(FetchOptions.RowsetSize, FetchOptions.Mode 이용)
  • 데이터를 페이징 단위(중간의 데이터 만)로 조회(FetchOptions.RecsSkip, RecsMax 이용)
  • 마스터/디테일 형식의 화면에서 키보드로 목록을 빠르게 움직여도 마지막에 위치한 상세정보만 표시해 불필요한 데이터 조회 방지(FetchOptions.DetailDealy 이용)

[샘플코드 받기 - 데브기어 github 페이지]


데이터를 지정건수 만큼 나눠서 가져오는 기능
데이터가 많은 경우 전체 데이터를 가져와 화면에 표시하는 것 보다 부분적으로 표시하고 추가로 데이터를 표시하는 것이 효과적일 수 있습니다.
FireDAC에서는 FetchOption의 Mode와 RowsetSize를 설정해 해당 기능을 구현할 수 있습니다. 다음 데이터목록을 가져오려면 TFDQuery.FetchNext 메소드를 호출합니다.
1
2
3
4
5
6
7
8
9
10
11
12
qryEmployee.Close;
if TCheckBox(Sender).Checked then
begin
  qryEmployee.FetchOptions.RowsetSize := 3;
  qryEmployee.FetchOptions.Mode := TFDFetchMode.fmManual;
end
else
begin
  qryEmployee.FetchOptions.Mode := TFDFetchMode.fmOnDemand;
end;
qryEmployee.Open;
btnFetchNext.Enabled := TCheckBox(Sender).Checked;

데이터 페이징 단위로 조회 기능
페이징 단위로 데이터를 조회할 수 있습니다. DBMS 자체에서 Top, Limit 명령을 통해 쿼리로 수행하던 기능을 FireDAC 컴포넌트로 구현할 수 있습니다.
1
2
3
4
qryEmployee.Close;
qryEmployee.FetchOptions.RecsSkip := 10;
qryEmployee.FetchOptions.RecsMax := 10;
qryEmployee.Open;

상세 데이터 조회지연 기능 구현
사원정보(qryEmployee)와 사원이 진행한 프로젝트(qryProject)로 목록/상세 기능 구현 후 체크박스(chkFetchRowsetSize) 체크 시 DetailDelay 옵션으로 지연 조회 하도록 설정
1
2
3
4
if TCheckBox(Sender).Checked then
  qryProject.FetchOptions.DetailDelay := StrToIntDef(Edit1.Text, 300)
else
  qryProject.FetchOptions.DetailDelay := 0;

관련 링크


FireDAC Skill Sprints 관련 글


번호 제목 글쓴이 날짜 조회 수
공지 [DelphiCon 요약] 코드사이트 로깅 실전 활용 기법 (Real-world CodeSite Logging Techniques) 관리자 2021.01.19 22591
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 21024
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 23082
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 28881
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 30050
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 25397
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 46348
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 182316
463 [다음 버전 정보] 멀티-디바이스 미리보기 창 관리자 2015.03.19 1366
462 [FireDAC Skill Sprints] 6. 전처리: SQL문을 유연하게 작성할 수 있는 Param와 Macro 사용하기 Humphery 2015.03.13 1773
» [FireDAC Skill Sprints] 5. Cascading Options: 고급기능을 활용 할 수 있는 FireDAC 옵션 Humphery 2015.03.11 1384
460 [FireDAC Skill Sprints] 4. ArrayDML로 30배 빠르게 데이터 입력하기 Humphery 2015.03.11 1560
459 엠바카데로에 직접 문의해 답변을 받아볼 수 있습니다.(퀄리티 포털 사용방법 안내) 험프리 2015.03.09 1266
458 [고객 사례- 의료, 델파이] 전북대학교 병원 file 관리자 2015.03.09 2366
457 [FireDAC Skill Sprints] 2. FireDAC으로 DBMS 사용 내역 추적, 모니터링 하기 Humphery 2015.03.07 1616
456 [FireDAC Skill Sprints] 3. 캐쉬를 이용한 업데이트와 자동증가필드(Identity) 적용 Humphery 2015.03.07 1549
455 웹사이트의 인증서 오류를 무시하고 http 결과 조회하기(WinInet 이용) Humphery 2015.03.06 2206
454 [XE7] iOS 시뮬레이터 배포 시 'Please specify exact device preset UUID.' 오류 대응 Humphery 2015.02.26 1570
453 안드로이드 하드웨어 백버튼 제어하기 Humphery 2015.02.25 2573
452 [VCL] TaskDialog 컴포넌트 소개 Humphery 2015.02.25 1132
451 이 달의 기술자료 - 2015년 03월 험프리 2015.02.25 15905
450 20150224 [온라인세미나] VCL개발자를 위한 Speed UP! RAD스튜디오 발표자료 관리자 2015.02.25 918
449 파이어몽키 용 그리드 컴포넌트 안내 - FirePower Humphery 2015.02.23 1468
448 [Delphi week 2015] 윈도우 3.11에서 델파이1.0 사용하기 관리자 2015.02.13 1162
447 [VCL] 에디트/버튼의 다양한 속성 소개 Humphery 2015.02.13 1795
446 [XE7] 안드로이드 WiFi 상태조회와 설정하기 Humphery 2015.02.12 1911
445 [XE7] 안드로이드 블루투스 활성화 조회와 설정하기 [1] Humphery 2015.02.12 1802
444 [무료 온라인 세미나] Delphi Week 2015 file 관리자 2015.02.07 1037