Background Image

FORUM

조회 수 5326 추천 수 0 댓글 10
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
Window10 64bit 
CUBRID Ver.
11.2
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, JDBC-11.1.0.0027-cubrid


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
안녕하세요. ibatis를 이용하여 큐브리드 dblink를 사용 하려 합니다.

 

SELECT * FROM DBLINK(DB링크명,

"SELECT * DB링크테이블

<isNotEmpty prepend="WHERE" property="파라미터">

PK = #파라미터#

</isNotEmpty>

" AS T (파라미터)

이런 식으로로 동적 태그를 사용하여 동적태그를 사용하려합니다만

동적태그를 포함하지 않고 수행한 쿼리의 경우에는 정상 작동되나, 동적태그를 포함하여 수행될 경우에는

dblink - not supported type null(0) 이라는 로그가 나타납니다.

 

하지만, 동적태그를 포함하여 오류가 났던 쿼리를 sqlgate에서 수행하면 결과가 잘 나옵니다.

구글링으로도 dblink - not supported type null(0)에 대한 정보를 한개도 찾을 수가 없네요.

 

무슨 문제일까요?

 

  • ?
    airnet 2022.07.06 11:32
    안녕하세요
    먼저 큐브리드를 이용해 주셔서 감사합니다.
    CUBRID/log 폴더를 압축하여 보내 주시면 검토후 답변 드리겠습니다.
    감사합니다.
  • ?
    김병욱 2022.07.07 08:57
    동적 쿼리 관련하여 현재 큐브리드의 dblink 제한 사항에 대해 말씀드리겠습니다.
    큐브리드의 dblink에 적용되는 쿼리에는 host-variable이 포함될 수 없습니다.

    SELECT a, b
    FROM dblink (srv, 'select a, b, c from tbl where a = ? and b = ?') AS t (a int, b varchar, c int)
    WHERE c > 0;

    위 쿼리를 실행하면 bind할 column의 타입이 정의되지 않아서 dblink 쿼리의 bind가 동작하지 않습니다 (not supported type null 에러 발생)
    아래와 같이 쿼리를 작성하면 predicate push down에 의해 dblink 쿼리에 대한 bind가 동작하게 됩니다.

    SELECT a, b
    FROM dblink (srv, 'select a, b, c from tbl where c > 0') AS t (a int, b varchar, c int)
    WHERE a = ? and b = ?;
  • ?
    Qubrid 2022.07.07 10:22

    안녕하세요.

    SELECT a, b
    FROM dblink (srv, 'select a, b, c from tbl where c > 0') AS X (a int, b varchar, c int)
    WHERE X.a = '2' and X.b = 'a1';

    이런 식으로 where 절을 가장 상단의 select 절의 조건으로 넣으면 ibatis 환경이 아닌 SQLGate에서 실행해도 오류메세지가 발생합니다.
    "dblink-[HY000][933][ORACLE][ORA]ORA-00933:SQL command not properly ended"

    그렇기 때문에 dblink() 안의 select 절에 where 조건을 넣었던 것입니다.

    또 특이사항이 있는데,

    SELECT a, b
    FROM dblink (srv, 'select a, b, c from tbl where c > 0') AS X (a int, b varchar, c int)
    LEFT JOIN tbl2 Y ON X.a=Y.a
    WHERE Y.f= '3'
    dblink 테이블이 아닌 조인했던 테이블에 대한 where절이 있는 위의 쿼리는 잘 실행이 되는데,

    SELECT a, b
    FROM dblink (srv, 'select a, b, c from tbl where c > 0') AS X (a int, b varchar, c int)
    LEFT JOIN tbl2 Y ON X.a=Y.a
    WHERE X.b= 'a1'
    처럼 dblink 테이블에 대한 where절이 있는 쿼리는 "dblink-[HY000][933][ORACLE][ORA]ORA-00933:SQL command not properly ended"라고 실행이 되지 않습니다.

    답변 기다리고 있겠습니다. 감사합니다.

  • ?
    bwkim 2022.07.07 10:50

    우선, 예시로 제시한 아래의 쿼리에 문법 오류가 있습니다.

    SELECT a, b
    FROM dblink (srv, 'select a, b, c from tbl where c > 0') AS X (a int, b varchar, c int),
    LEFT JOIN tbl2 Y ON X.a=Y.a
    WHERE X.b= 'a1'

    아래와 같이 "," 없이 LEFT JOIN 쿼리를 작성해야 합니다.

    SELECT a, b
    FROM dblink (srv, 'select a, b, c from tbl where c > 0') AS X (a int, b varchar, c int) LEFT JOIN tbl2 Y ON X.a=Y.a
    WHERE X.b= 'a1'

  • ?
    Qubrid 2022.07.07 11:00

    네 예시에 오타가 있었습니다. ","없이 봐주시면 감사하겠습니다.

  • ?
    bwkim 2022.07.07 19:00
    오라클 기준으로 dblink query를 재작성 하는 과정에 오류가 발견되었습니다.
    재작성된 쿼리가 oracle에서 실행될 수 없는 문법이 만들어지는 오류로, 이를 바로 잡아서 빠른 시일 내에 패치 버전을 배포할 예정입니다.

    우선 우회 방법은,
    - NO_PUSH_PRED 힌트를 사용해서 predicate가 push down 되지 않도록 하는 방법과 (성능이 다소 저하될 수 있음)
    - 혹은 host변수 대신 iBatis에서 상수를 대입해 주는 방법이 있습니다.

    패치 버전 배포까지 우회 방법을 사용해야 하는 점, 널리 양해 부탁드립니다.
  • ?
    Qubrid 2022.07.07 20:08
    답변 감사합니다..
  • ?
    오명환 2022.08.01 14:53
    해당 오류를 수정한 11.2.1 버전이 릴리스 되었습니다.
    자세한 릴리스 내용은 https://www.cubrid.com/release_note/3837571 를 참고하시고, https://www.cubrid.com/downloads 에서 받아 사용하시면 되겠습니다.
  • ?
    리들러 2022.09.07 19:47

    11.2.1 버전에서도 동일한 현상이 나타납니다.

    하는수 없이 # 대신 $ 를 사용해서 사용중 입니다.

  • ?
    airnet 2022.09.08 09:53
    CUBRID\log\gateway\sql_log 의 로그를 보내 주시면 확인후 답변 드리겠습니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 21 admin 2024.04.23 143798
4048 getlogfileinfo api 문의 6 11시38분 2024.07.22 5032
4047 broker log 중 sql이 db에서 실행되었는지 알수 있나요? 1 11시38분 2024.07.22 5245
4046 auto_increment 제거 1 레드혁 2024.07.18 5094
4045 Resource allocation failed. Raise up 'max_bestspace_entries=...' 오류 관련 문의 1 썬책임 2024.07.18 5222
4044 특정시간 또는 일별로 insert,update 이력을 알고싶습니다. 4 DB구루 2024.07.12 5237
4043 슬로우쿼리 포맷을 알고 싶습니다. 6 11시38분 2024.07.10 5013
4042 dbeaver connection error - unknown class 1 file 비밀 2024.07.09 5275
4041 통계정보 갱신 작업을 crontab에 등록하려고 합니다. 스키마별로, 테이블별로 등록하는 스크립트 또는 방법을 알려주세요. 3 DB구루 2024.07.09 5225
4040 큐브리드 브로커 리스트 명단 및 log 수집 2 11시38분 2024.07.09 5185
4039 이중화 한 Slave 서버가 다운된 후 Master 서버에서 master 상태로 있는 것이 아닌 slave 상태로 있습니다. 3 file 로키 2024.07.09 5077
4038 백업파일을 받았습니다. 3 mango 2024.07.08 5013
4037 Timezone 설정 관련 문의 6 steve 2024.07.07 5179
4036 큐브리드 로더 1 자바조 2024.07.05 5164
4035 cubrid_server 메모리 사용량 문의 1 그로구 2024.07.04 5070
4034 cubrid table 데이터 delete 처리 문의 1 안녕 2024.07.03 5212
4033 Java import java.sql.DatabaseMetaData 1 file 레드혁 2024.07.01 5157
4032 큐브리드 이미 생성된 테이블 create문 출력하는 방법 문의 1 hwson 2024.06.27 5207
4031 정상작동 하다가 Locales for language 'en_US' are not available with charset 'ksc-euc' 오류로 업데이트 안됩니다. 1 나라디 2024.06.25 5073
4030 cci_prepare의 handle을 쓰레드에서 사용할 때 safe 여부 1 가을이아빠 2024.06.20 5358
4029 gettransactioninfo api sql text 조회 안됨 6 11시38분 2024.06.19 5087
Board Pagination Prev 1 ... 6 7 8 9 10 11 12 13 14 15 ... 213 Next
/ 213

Contact Cubrid

영업문의 070-4077-2112 / 기술문의 070-4077-2148 / 대표전화 070-4077-2110 / Email. contact_at_cubrid.com
Contact Sales