Background Image

FORUM

조회 수 2701 추천 수 0 댓글 4
?

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
리눅스 64비트
CUBRID Ver.
10.1.1.7691 
CUBRID TOOL Ver.
10.0.0.1
응용 환경(API)
JAVA

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------


전자정부 + mybatis + 큐브리드 10.1 사용중입니다.


#{aaa , jdbcType=VARCHAR} 쪽에서 일부 에러가 나길래 


쿼리를 훑어보니까 아래처럼 사용한 데서만 에러가 발생했습니다.


파라미터는 map<String,Object> 형식으로 담아오고 담을 때 값은 String입니다.


SELECT

CASE WHEN TEMP.CHG_TYPE = 'UP'   << 요기

THEN ... 생략 

END AS COLNAME

FROM

(

SELECT

              SUB_DATA3.SYSTEM_CD                      AS SYSTEM_CD

              , #{chgType, jdbcType=VARCHAR}       AS CHG_TYPE  

FROM 

  ( ... 생략 ) 

) TEMP 



위에 표시해놓은 비교 부분에서 에러가 나던데 


오라클에서는 에러가 없는 부분이라 큐브리드는 데이터 형식 처리가 다른건가요.


오라클 드라이버랑 차이점이 있는건지 궁금합니다.


저 'UP'이라고 된 부분을 함수 사용해서 UPPER('UP') 이런 식으로 바꾸면 에러가 안나는 상황이구요.


에러는 다 치환해서 해결하면 될 것 같긴 한데 원인이 궁금해서 문의 드립니다.

  • ?
    오명환 2018.04.10 10:08
    문의하신 내용만으로 어떤 문제인지를 확인하기 어렵습니다.
    cubrid 서버의 $CUBRID/log/broker/sql_log 아래에 있는 로그 파일들 중에서 실행하신 mybatis 질의가 어떤 질의로 바뀌었는지 확인을 해 보시는 것이 좋을 것 같습니다.

    현재 오류는 임의적으로 character data type을 원하시는 data type으로 변경할 수 없다는 오류입니다.
    로그에서 찾으신 질의를 가지고 csql 또는 cubrid manager에 수행해보시면서 확인을 부탁드립니다.
  • ?
    잉여개발자 2018.04.10 17:34

    간단한 쿼리로 테스트하려고 바꾸고 돌려보니

    18-04-10 17:30:43.687 (9) execute_all srv_h_id 1
    SELECT (CASE WHEN TMP.A = 'UP' THEN 'Y' ELSE 'N' END) AS SHOW
    FROM (
    SELECT ? as A
    FROM
    DB_ROOT
    ) AS TMP

    18-04-10 17:30:43.687 (9) bind 1 : VARCHAR (10)SYST_0002
    18-04-10 17:30:43.689 (9) execute_all error:-181 tuple 0 time 0.001, EID = 9

    로그는 이거만 남네요.

  • ?
    오명환 2018.04.11 09:36
    -181 오류메세지는 Cannot coerce value of domain character to domain " 입니다.
    보내주신 질의를 보니, db_root에서 ? 에 의해 결정된 값을, 상위에 select에서 사용하다 보니 query execute 시에 type 결정(variable)을 못합니다.
    이런 경우에는 명시적으로 type를 아래와 같이 정의해주시면 됩니다.

    SELECT cast(? as varchar) as A
    FROM
    DB_ROOT
  • ?
    잉여개발자 2018.04.11 10:57
    캐스팅 지정 해줘야하는군요 감사합니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 51
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
3394 데이타베이스 로그인시 사용자 이름이 한글자 밖에 입력이 안될때 3 초보 2010.04.08 11860
3393 데이타 올리기로 데이타 삽입후 db_serial 변경 문의 1 초보 2010.04.08 10521
3392 multiset 관련 질문은 CUBRID 7.3 Q&A 게시판으로 이동되었습니다. 1 admin 2010.04.09 9643
3391 테이블 파티션 문의 4 초보 2010.04.09 10186
3390 테이블 파티션 추가 문의 1 초보 2010.04.09 10470
3389 테이블 파티션 -> 일반 테이블 변경 문의 4 초보 2010.04.09 10623
3388 조인 업데이트 구문 문의 1 초보 2010.04.09 13972
3387 해시분할 문의 2 초보 2010.04.10 9983
3386 리눅스에서 큐브리드 메니저 에러 2 file 태랑 2010.04.13 10727
3385 큐브리드설정 문의 5 초보 2010.04.13 10026
3384 쿼리 오류인데 어쩌해야할지 3 노닝 2010.04.13 12779
3383 트랜잭션 교착상태 1 초보 2010.04.14 11936
3382 서버사양에 대한 설정문의 5 초보 2010.04.14 9927
3381 ODBC를 사용해서 디비작업이 안되요 1 요한 2010.04.15 11142
3380 뷰테이블 성능 문의드립니다 1 초보 2010.04.15 11702
3379 sql_log 정리 문의 3 초보 2010.04.15 9893
3378 ODBC 1.4버젼을 사용하니까 ASP함수가 실행되지 않아요 1 요한 2010.04.15 10685
3377 홀따옴표 처리 문의 1 초보 2010.04.15 14679
3376 Cubrid Start 실패 1 흐들 2010.04.16 13474
3375 트리거 조건 문제 1 yoon 2010.04.16 13039
Board Pagination Prev 1 ... 26 27 28 29 30 31 32 33 34 35 ... 200 Next
/ 200

Contact Cubrid

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