자유롭게 질의 및 응답을 할 수 있는 게시판입니다. 개발자 여러분의 답변이 큰 도움이 됩니다. 
  • 제품설치/등록 오류 문의: 설치/등록 Q&A 이용 (제품 구매 고객 한정)

본 게시판은 개발자들이 자유롭게 질문과 답변을 공유하는 게시판입니다.
* 따라서 최대한 정중하게 질문을 올려 주세요.
* 질문을 상세히 작성해 주실 수록 좋은 답변이 올라 옵니다.
* 다른 분들도 참고할 수 있도록 결과 댓글 필수(또는 감사 댓글)
(결과 댓글을 달지 않는 경우 다음 질문에 대한 답변이 달리지 않는 불이익이 있을 수 있습니다.)
-----------------------------------------------------------------------------------------------

델파이 7  -> 도쿄로 마이그레이션 중입니다.

기존 ADO 쿼리에서 FD쿼리로 변환작업을 진행중인데, 

MapRule을 통해 BCD 필드를 integer, float 필드로 변환하였습니다.

헌데 일부 쿼리는 TBCDfield가 아닌 TFMTBCDfield로 로드가 되는데, 어떠한 경우에 fmtbcd필드로 로드가 되는것인가요?

또한 FMTbcd필드는 maprule의 정책이 적용이 되질 않습니다.

거기에 maprule은 FDConnection에만 적용해두면 해당 커넥션을 사용하는 FDquery에 모두 적용이 되는것인가요??

(현재 적용이 되질않나 fdquery component에 하나씩 maprule 생성.)

 

정리하자면, 

1. BCDfield와 FMTBCDfield의 차이점.(어떠한 경우에 FMTBCD로 로드되는지?)

 

2. FMTBCDfield에 Maprule 적용방법.

 

3. maprule은 FDConnection에만 적용해두면 해당 커넥션을 사용하는 FDquery에 모두 적용이 되는것인지?

 

4. maprule에서 widestringfield를 stringfield로 바꿀 수 있는지?

 

 

하기 테스트해본 소스입니다.

====================

  object FDConnection1: TFDConnection

    Params.Strings = (

      'DriverID=ora'

      'Database=***'

      'Password=****'

      'User_Name=****')

    FormatOptions.AssignedValues = [fvMapRules, fvDataSnapCompatibility]

    FormatOptions.OwnMapRules = True

    FormatOptions.MapRules = <

      item

        PrecMax = 10

        PrecMin = 0

        ScaleMax = 0

        SizeMin = 0

        SourceDataType = dtFmtBCD

        TargetDataType = dtInt32

      end>

    FormatOptions.DataSnapCompatibility = True

    Connected = True

    LoginPrompt = False

    Left = 360

    Top = 216

  end

  object FDQuery1: TFDQuery

    Connection = FDConnection1

    SQL.Strings = (

      'select 1 f1, 2.3 f2, 3.12345 f3'

      'from dual')

    Left = 440

    Top = 224

    object FDQuery1F1: TFMTBCDField

      FieldName = 'F1'

      Origin = 'F1'

      Precision = 32

      Size = 12

    end

    object FDQuery1F2: TFMTBCDField

      FieldName = 'F2'

      Origin = 'F2'

      Precision = 32

      Size = 12

    end

    object FDQuery1F3: TFMTBCDField

      FieldName = 'F3'

      Origin = 'F3'

      Precision = 32

      Size = 12

    end

  end

번호 제목 글쓴이 날짜 조회 수
공지 [프로그래밍 강의] 2021.6~2021.12 관리자 2015.01.22 15947
공지 유용한 관련 사이트 관리자2 2014.03.20 54752
공지 본 게시판은 개발자 여러분들의 질문과 답변을 공유하는 공간입니다. 관리자 2012.01.10 98222
1699 링크드리스트 구현 질문입니다. 델리아끼 2015.11.04 351
1698 XE8 OS 32bit에서는 FireDAC CreateDB가 잘 되는데 64bit로 빌더를 바꿔서 하면 에라가 발생? 바람돌이 2016.07.12 352
1697 delphi 베를린 android database 에러 질문합니다. [4] devdev 2018.10.05 352
1696 3D 부분을 실습해보고 있는데 카메라 각도에 대한 질문이 있습니다. [2] 손보라 2015.03.27 352
1695 [XE8 출시세미나] XE8에서 윈도우10 버전을 지원하나요? [1] Humphery 2015.04.30 352
1694 IBLite 연결 질문~ [2] file 아놀드 2016.01.11 352
1693 MDI Child Dll [2] 라시드 2015.10.26 352
1692 글자 깨짐 [2] 똘귀아빠 2015.10.28 352
1691 안드로이드 개발시 TComboBox 폰트 적용을 어떻게 하나요? [4] 광땡 2015.10.28 352
1690 MacOS 빌드 Error [1] Sangin 2021.08.03 353
1689 데이터스냅 콜백 오류 문의 [3] file 회원 2016.10.14 353
1688 오라클-FireDAC 배포시 cannot initialize oci environment 오류 발생 문의 드립니다. [3] agallee 2020.10.28 353
1687 [질문] DataSnap과 Mobile 연결 [2] 오는새벽 2021.02.25 353
1686 rest debugger 이후 복사한 컴포넌트에서 데이터를 불러올때 문제 발생 (책: 90page) [2] file youngdel 2016.04.20 354
1685 TWebBrowser를 통한 JS에서 FMX앱의 Function, Procedure 실행 문의 [1] 나즈나 2017.11.10 354
1684 설치 관련 문의.... [4] 삼이 2020.04.21 354
1683 (자문 자답) JSON 안의 특정 필드 값만 바꾸는 방법은 TJsonPair를 사용하면 간단합니다. (POST, PUT 방식으로 특정 필드만 교체할 때, 특히 유용) [2] WhiteC 2020.06.15 354
1682 XE8 Android MainForm 문제 불나방 2015.04.29 354
» bcdfield 관련 마이그레이션 작업 문의 [3] mckim 2018.07.13 355
1680 [XE8 출시세미나] 파이어몽키 앱에서 안드로이드 라이브러리에 포함된 화면(Activity)를 연동하려면 어떻게 하나요? [1] Humphery 2015.04.30 355