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 4263
3816 /home/jenkins/workspace/cubrid_release_10.1/src/transaction/boot_cl.c, line 1138 CODE = -971 Tran = -1, EID = 1Program 'tranlist' (pid ) connected to database server 'test' on the host 'localhost' 4 jmkim 2023.03.13 187
3815 macOS CUBRID 다운로드 질문 1 bk9395 2023.03.13 180
3814 CUBRID 11.2 & CUBRID Aadmin 11.1 오류 문의 2 file 붉은구름 2023.03.08 133
3813 도커에서 설치시 접속 문의드립니다. 1 핫산 2023.03.07 360
3812 특수문자 포함 LIKE검색 1 SEO 2023.03.06 143
3811 cubrid admin 질문 드립니다. 3 file 초코초코초 2023.03.06 116
3810 plugin방식 호출 1 file 네오랜덤 2023.03.04 127
3809 서브쿼리시 질문드립니다. 2 dev123123 2023.02.28 146
3808 Cubrid DB 의 sqoop 사용시 옵션 문의 1 망고라떼 2023.02.28 94
3807 큐브리드 통계정보 관련 문의드립니다. 1 초코초코초 2023.02.26 110
3806 cubrid 매니저 패스워드 공용으로 사용하는건가요?? 2 학아 2023.02.24 166
3805 list 합수의 결과를 varchar 컬럼에 insert 시 오류 문의 1 file 플레이어블 2023.02.24 120
3804 LOG 설정 관련 질문입니다. 1 jemin 2023.02.23 84
3803 큐브리드 unload 문의드립니다. 5 초코초코초 2023.02.22 204
3802 Mac OS 에서 Cubrid Manager 실행이 안됩니다. 1 file 엘L 2023.02.20 273
3801 쿼리 플랜 cardinality, cost 이상 1 parknnna 2023.02.16 180
3800 조건절 in 에 들어가는 순서대로 뽑고 싶습니다. 1 구르마도리 2023.02.15 89
3799 Cubrid 11.2 접속 문제. 1 엘L 2023.02.15 130
3798 cubrid 매니저 백업 자동화 추가 비활성 1 제리리 2023.02.15 120
3797 Mac OS 큐브리드 매니저 설치 문제 6 file DJ 2023.02.13 280
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 ... 199 Next
/ 199

Contact Cubrid

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