엠바카데로에서 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 옵션 샘플프로그램
FireDAC 옵션 샘플프로그램
이 샘플에서는 FetchOptions을 이용해 아래 3가지 기능을 구현했습니다.
- 테이블에 데이터가 많은 경우 신속하게 화면에 표시하기 위해 데이터를 나눠서 가져오기(FetchOptions.RowsetSize, FetchOptions.Mode 이용)
- 데이터를 페이징 단위(중간의 데이터 만)로 조회(FetchOptions.RecsSkip, RecsMax 이용)
- 마스터/디테일 형식의 화면에서 키보드로 목록을 빠르게 움직여도 마지막에 위치한 상세정보만 표시해 불필요한 데이터 조회 방지(FetchOptions.DetailDealy 이용)
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;
qryEmployee.Close; qryEmployee.FetchOptions.RecsSkip := 10; qryEmployee.FetchOptions.RecsMax := 10; qryEmployee.Open;
if TCheckBox(Sender).Checked then qryProject.FetchOptions.DetailDelay := StrToIntDef(Edit1.Text, 300) else qryProject.FetchOptions.DetailDelay := 0;
관련 링크
- 엠바카데로 기술문서 - Setting Options (FireDAC)
- TFDFetchOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDFetchOptions
- TFDFormatOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDFormatOptions
- TFDUpdateOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDUpdateOptions
- TFDResourceOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDResourceOptions
- TFDTxOptions 기술문서 - http://docwiki.embarcadero.com/Libraries/XE7/en/FireDAC.Stan.Option.TFDTxOptions
- FormatOption : Data Type Mapping(FireDAC)
- [유투브] FireDAC Skill Sprint 다시보기
- [온라인교육] FireDAC 무료 온라인 교육 안내