Background Image

FORUM

조회 수 1437 추천 수 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 도구 출시 안내 admin 2024.04.23 48
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
3794 테이블/컬럼명 자동완성 설정문의 5 file dfdfdd 2023.02.10 205
3793 드라이버버전 변경방법문의드립니다. 1 file dfdfdd 2023.02.10 124
3792 큐브리드 설치 문의 1 file 팡이 2023.02.09 115
3791 attempt to divide by zero .. 조회문제 도와주세요 1 file 아프월 2023.02.07 270
3790 큐브리드 컬럼 디폴트값 2 백수인 2023.02.06 205
3789 ddl_audit_log=yes 가 없을때 디폴트 값 2 바람발마발 2023.02.01 87
3788 numeric type 의 입력 가능한 최대 값 1 정우아빠 2023.01.31 117
3787 집합함수 이용 시 정렬 관련하여 문의드립니다. 2 플레이어블 2023.01.27 94
3786 안전한 암호화 알고리즘 사용 문의드립니다. 1 보안진단 2023.01.27 112
3785 뷰를 이용한 조인쿼리 시스템 에러 문의 2 플레이어블 2023.01.19 124
3784 설시치 문의 드립니다. 4 file 큐브리드궁금 2023.01.18 152
3783 임의용량에 대해 문의 드립니다. 1 김은지 2023.01.18 57
3782 윈도우용 python 드라이버 설치 오류 1 리치타이거 2023.01.18 82
3781 cubrid 드라이버 설치 오류 13 file h2h2 2023.01.17 119
3780 큐브리드 버전 업그레이드 관련 문의 드립니다. 1 초코초코초 2023.01.17 87
3779 python 3.9 지원 문의 1 리치타이거 2023.01.17 85
3778 Python Cubrid DB 연동 시 import _cubrid 오류 1 이노무소오파 2023.01.13 148
3777 cci에서 패스워드 암호화 사용 방법 1 가을이아빠 2023.01.12 55
3776 데이터베이스 백업, 복구(backupdb, restoredb) 1 wiz 2023.01.12 279
3775 실리콘 맥(M1, ARM) 큐브리드 매니저 지원 문의 2 큐유저 2023.01.09 238
Board Pagination Prev 1 ... 6 7 8 9 10 11 12 13 14 15 ... 200 Next
/ 200

Contact Cubrid

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