Background Image

FORUM

조회 수 1436 추천 수 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 4441
3986 tomcat7 + cubrid 1 깽즈야 2012.07.27 91016
3985 원격접속이 안되네요????????? 2 Chris 2013.07.23 89530
3984 현재 연결은 원격 호스트에 의해 강제로 끊겼습니다 1 바람바람 2013.05.29 84883
3983 CUBRID 7.3 + zeroboard XE 관리자 로그인 에러 1 윤희서 2009.01.17 83642
3982 cub_master: Cannot bind local address... aborting.... Address already in use 4 박상현 2008.11.28 83563
3981 큐브리드 다운로더 오류 발생 5 file 차오이 2008.11.22 78483
3980 zeroboard XE 설치시 'database connect fail' error 4 윤희서 2009.01.16 78164
3979 Image 데이터타입 사용방법 3 AD 2008.11.25 73850
3978 clob 문의 1 김해영 2012.11.29 73007
3977 linux server 환경에서 php 버전은 어떤걸로 선택해야하는지. 1 거기 2008.11.30 66366
3976 델파이에서는 어떻게 사용할수 있을까요? 2 이상원 2008.11.29 65566
3975 if exists 조건 처리문? 2 콩이아부지 2013.03.06 63606
3974 update 쿼리를 이용한 시리얼 수정에 관하여 1 인경수 2008.11.27 63453
3973 큐브리드 2008 설치시 윈도우 서비스에 등록되지 않습니다. 3 file 진이 2008.11.22 63170
3972 CUBRID 7.3 + zeroboard XE 관리자 로그인 에러 1 윤희서 2009.01.17 62130
3971 큐브리드 maven repository 관련 문의 3 StoneHouse 2013.04.30 61468
3970 메니저에서 접속 안되는 오류 2 유나인 2013.08.16 61067
3969 .NET DB 제어를 위한 방법. 2 우페 2008.11.23 60878
3968 JDK가 두개 설치된 경우 선택적으로 JDK를 설정 할 수 있는 방법은 없는지요 1 GoFly 2008.11.28 60614
3967 데이터 이관시 소유자 변경 가능한가요??? 1 델몬트 2013.08.08 60066
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 200 Next
/ 200

Contact Cubrid

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