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

Q, 

FireDAC-MySQL 사용 중 '!abc'와 같이 느낌표와 문자 사용 시 문자가 없어지는 현상이 발생합니다.

 

  sql := 'UPDATE USER SET ADDRESS = ''!abcd'' WHERE USER_ID = 1';

  FDQuery2.SQL.Text := sql;
  FDQuery2.ExecSQL;
 

위와 같이 실행하면, ADDRESS 필드의 값이 공백으로 업데이트 됩니다.

 

A, 

코드를 분석해 보니, MySQL에서 느낌표('!')를 매크로 접두문자로 사용하는 것으로 파악됩니다.(관련된 문서는 찾기 어렵네요.)

FireDAC.Phys.SQLPreprocessor.pas 소스코드의 ProcessCommand 메소드 소스 보면 아래와 같은 구문이 있습니다.

(일부)

      case GetChar of
      '!', '&':
        if Instrs * [piExpandMacros, piCreateMacros] <> [] then begin
          ProcessMacro(FCh);
          GetChar;
        end;
위 코드는 느낌표로 시작되는 경우 매크로로 인식해 매크로 처리를 합니다.

 

위 과정 중 문자열이 누실될 수 있습니다.

 

해결방법은 다음과 같습니다.(1번 방법이 가장 좋은 방법입니다.)

1) 파라메터를 사용합니다. SQL문을 직접 작성하는 경우 SQL Injection과 같은 보안취약점이 발생할 수 있습니다.

가능한 파라메터를 사용하시기 바랍니다.

  sql := 'UPDATE USER SET ADDRESS = :ADDR WHERE USER_ID = 1';

  FDQuery2.SQL.Text := sql;
  FDQUery2.ParamByName('ADDR').AsString := '!abcd';
  FDQuery2.ExecSQL;
 

2) 매크로를 사용하지 않도록 FDQuery 옵션을 수정합니다.

TFDQuery.ResourceOptions의 MacroCreate, MacroExpand 항목을 False로 변경합니다.

번호 제목 글쓴이 날짜 조회 수
공지 [프로그래밍 강의] 2021.6~2021.12 관리자 2015.01.22 17213
공지 유용한 관련 사이트 관리자2 2014.03.20 56087
공지 본 게시판은 개발자 여러분들의 질문과 답변을 공유하는 공간입니다. 관리자 2012.01.10 99527
1133 REST API 컴포넌트 설치와 클라이언트 개발 문의드립니다 [1] 가나다 2019.11.22 331
1132 데이터스냅에서 접속 끊어짐에 대처할 수 있는 방법이 있습니까? [2] 거북이 2015.10.15 331
1131 10.4 인데요 안드로이드 IDE에서 안드로이드 기기 연결이 안됩니다. [2] kivalan 2020.08.25 332
1130 오픈소스 scannerMapp 에서 아래와 같은 에러가 나옵니다. [1] 김종찬 2018.07.30 333
1129 C++ Dll 구조체 데이터형식 관련 문의 [2] woofer 2020.03.25 333
1128 FDStoredProc 파라메터 오류 문의 [1] arabianwine 2020.06.11 333
1127 delphi 10.3.2 TRestClient 구조가 변경된듯 [1] 미스터몽키 2019.09.22 334
1126 Delphi 10.3 에서 iOS 시뮬레이터 사용 가능한 방법이 없나요? [2] samsmin 2020.02.25 335
1125 Delphi 10.2 사용자 정의 컴포넌트 등록후 디자인타임에 안보임 file 미스터몽키 2019.08.23 336
1124 델파이 JSON 관련 질문 있습니다. [2] yawayo 2020.07.20 336
1123 애플 푸시알림을 사용하기 위해서 설정하는 방법은? [1] 화이부동 2016.12.22 338
1122 다른 크로스플랫폼 개발 도구와 비교한다면??? [3] 라드 2015.07.30 339
1121 Zigbee 통신 어떻게 하는지 알고 싶습니다. [1] 이노야 2016.03.14 339
1120 ios 앱 외부 url 호출 방법 문의 [1] 사랑남 2015.08.28 340
1119 ios [1] file 지구수비방위대 2021.08.09 341
1118 델파이xe win 7 64bit 설치문의 file kwy0702 2017.05.30 342
1117 델파이 (10.3.3)로 iOS앱 FireBase Push Notification 구현가능한가요? [3] samsmin 2020.03.20 342
1116 Rave Reports Component는 별도로 구매해야 하나요? [2] 바람돌이 2015.11.13 342
1115 델파이 MDI 폼에서 쪽지 알람 기능 가능? [1] 가나다 2021.03.10 342
1114 델파이 RIO Webbrowser size 문의? [2] silkroad99 2018.12.27 343