자유롭게 질의 및 응답을 할 수 있는 게시판입니다. 개발자 여러분의 답변이 큰 도움이 됩니다.
- 제품설치/등록 오류 문의: 설치/등록 Q&A 이용 (제품 구매 고객 한정)
Delphi dbExpress > FireDAC 마이그레이션 관련 문의
2016.09.08 12:21
본 게시판 사용시 당부 사항
* 이 게시판은 자유롭게 질문을 올리고 자발적으로 답변을 공유하는 게시판입니다.
* 어느 누구도 답변을 달아야만 하는 책임은 없습니다.
* 따라서 질문을 올리실 때에는 최대한 자세하고 정중하게 질문을 올려 주세요.
* 최대한 질문을 자세히 올려야 답변도 자세히 올라 옵니다.
* 본 질문에 답변을 주시는 여러 개발자님들께 미리 감사드립니다.
-----------------------------------------------------------------------------------------------
Delphi7 > Delphi XE10.1 , dbExpress > FireDAC 마이그레이션 관련 문의드립니다.
MySql에서 SELECT 한 데이터를
Firebird 에 INSERT 하는 작업을 TSQLQuery 만 TFDQuery 로 아래와 같이 변경하였습니다.
( FDConnection Charterset 은 csNONE 입니다)
with FDQuery do
begin
Close();
Sql.Clear();
Sql.Add(' INSERT INTO TABLE_A( A, B) VALUES (:A, :B) ');
Params.ParamByName('A').AsString := 'Recv Document 문서의 제목입니다';
Params.ParamByName('B').AsString := '홍길동';
ExecSql();
end;
위 SQL을 실행하면 DB에는
'Recv Document 문서의' , '홍?' 처럼 내용이 짤려서 저장됩니다.
원인을 찾다보니 아래처럼 Parameter의 DataType을 명확히 지정해야 정상적으로 insert 되는 것을확인하였습니다.
ParamByName('A').DataType := ftString;
ParamByName('A').AsString := 'Recv Document 문서의 제목입니다';
ParamByName('B').DataType := ftString;
ParamByName('B').AsString := '홍길동';
FireDAC에서는 Parameter의 DataType을 지정하지 않으면
한글이 포함된 Value 가 짤려서 insert 되는 문제가 발생하는 것인지 궁굼합니다.
파라미터를 사용한 소스 전체를 찾아 모두 DataType을 지정해야하는 작업이 너무많아서요
fireDAC에서 다른 대안은 없는 건가요?
댓글 2
Delphi dbExpress > FireDAC 마이그레이션 관련 문의
2016.09.08 12:21
본 게시판 사용시 당부 사항
* 이 게시판은 자유롭게 질문을 올리고 자발적으로 답변을 공유하는 게시판입니다.
* 어느 누구도 답변을 달아야만 하는 책임은 없습니다.
* 따라서 질문을 올리실 때에는 최대한 자세하고 정중하게 질문을 올려 주세요.
* 최대한 질문을 자세히 올려야 답변도 자세히 올라 옵니다.
* 본 질문에 답변을 주시는 여러 개발자님들께 미리 감사드립니다.
-----------------------------------------------------------------------------------------------
Delphi7 > Delphi XE10.1 , dbExpress > FireDAC 마이그레이션 관련 문의드립니다.
MySql에서 SELECT 한 데이터를
Firebird 에 INSERT 하는 작업을 TSQLQuery 만 TFDQuery 로 아래와 같이 변경하였습니다.
( FDConnection Charterset 은 csNONE 입니다)
with FDQuery do
begin
Close();
Sql.Clear();
Sql.Add(' INSERT INTO TABLE_A( A, B) VALUES (:A, :B) ');
Params.ParamByName('A').AsString := 'Recv Document 문서의 제목입니다';
Params.ParamByName('B').AsString := '홍길동';
ExecSql();
end;
위 SQL을 실행하면 DB에는
'Recv Document 문서의' , '홍?' 처럼 내용이 짤려서 저장됩니다.
원인을 찾다보니 아래처럼 Parameter의 DataType을 명확히 지정해야 정상적으로 insert 되는 것을확인하였습니다.
ParamByName('A').DataType := ftString;
ParamByName('A').AsString := 'Recv Document 문서의 제목입니다';
ParamByName('B').DataType := ftString;
ParamByName('B').AsString := '홍길동';
FireDAC에서는 Parameter의 DataType을 지정하지 않으면
한글이 포함된 Value 가 짤려서 insert 되는 문제가 발생하는 것인지 궁굼합니다.
파라미터를 사용한 소스 전체를 찾아 모두 DataType을 지정해야하는 작업이 너무많아서요
fireDAC에서 다른 대안은 없는 건가요?
FireDAC 매핑 룰(TFDConnection.FormatOptions.MapRules)을 설정해 보시는 건 어떨까요?
매핑 룰은 DB와 소스코드의 데이터 타입이 다를때 두가지 데이터타입을 매핑해 주는 기능입니다.
TFDConnection.FormatOptions,OwnMapRules 속성을 True로 설정 후
MapRules에 아래 패턴을 추가해 보세요.
SourceDataType = dtAnsiString
TargetDataType = dtWideString
자세한 내용은 아래 링크를 참고하시기 바랍니다.
http://docwiki.embarcadero.com/RADStudio/Berlin/en/Data_Type_Mapping_(FireDAC)
테스트 결과 답변 부탁드립니다.