Background Image

FORUM

조회 수 1427 추천 수 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
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4272
3936 DB 서버가 start 되지 않아 문의드립니다. 4 그로구 2023.12.19 118
3935 Rocky Linux 9에 큐브리드 9.3버전 설치 3 범이 2023.12.19 96
3934 인덱스 사용 관련하여 문의드립니다. 1 neighbor 2023.12.12 102
3933 cubrid admin접속 불가 문의 1 file 이하륜 2023.12.11 85
3932 restoredb 진행시 오류가 발생합니다. 3 samsam 2023.12.08 104
3931 SQL 행, 10분이상 지연 시 해제 및 설정 방법 문의 드립니다 2 kdman 2023.12.06 102
3930 에러코드 -51 질문드립니다. 1 kkkkwwakji 2023.12.01 98
3929 오류 메세지 문의 Derived column names are not allowed for simple class specifications. 4 달이맘 2023.12.01 117
3928 큐브리드 매니져 접속오류문의 드립니다. 3 file 원샷 2023.11.30 129
3927 query 최대 실행 줄 수 가 어떻게 되나요?? 3 file kjn4345 2023.11.24 147
3926 같은 그룹에 속한 OS계정에서의 csql접속 3 f0081 2023.11.22 106
3925 비슷한 조건의 환경에서 select 질의시 오류가 발생합니다. 1 msbb8585 2023.11.21 97
3924 임시볼륨 늘어나는 문제 1 angdoo 2023.11.21 85
3923 DB 데이터 이전 관련 3 별린 2023.11.20 113
3922 Java Maven Repository 2 내멋으로 2023.11.16 112
3921 Cubrid의 Window 버전의 Broker Port 구성 방식 2 jhlee 2023.11.15 90
3920 [CUBRID Admin] ENUM 데이터 내보내기 1 tree1891 2023.11.14 100
3919 CUBRIDException: Data type references are incompatible. 에러관련 쿼리질문 15 file yhpark 2023.11.14 214
3918 사용자 삭제 시 소유한 오브젝트를 함께 삭제하는 방법 1 f0081 2023.11.14 127
3917 unloaddb 에러 확인 요청. 1 정현 2023.11.13 83
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 199 Next
/ 199

Contact Cubrid

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