Background Image

FORUM

조회 수 23177 추천 수 0 댓글 2
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
select case
            when to_number(to_char(sysdate, 'd')) between 4 and 7 then sysdate + (10 - to_number(to_char(sysdate, 'd')))
            else sysdate +(3-to_number(to_char(sysdate, 'd'))) end
from db_root


화요일이 지났으면 다음 주 화요일을 조회하고, 화요일이 지나지 않았으면 이번 주 화요일을 출력하는 쿼리입니다.
쿼리에는 이상이 없는 것 같은데, "Semantic: '+' operator is not defined on types date and numeric. " 이라는 오류를 발생시키네요.
오라클에서는 이상이 없이 조회가 되는데요.
오라클 만의 특별한 명령어를 쓴 것도 아닌데...
무엇이 문제일까요?
  • ?
    시난 2009.07.29 20:47

    음.. 이 문제는 numeric과 date 형의 오퍼레이터(+,-) 연산이 호환되지않아서 나타나는 것 같습니다.
    date형과 integer는 잘 되므로..

    다음과 같이 수정하시면 해결됩니다.. (더 좋은 의견 있으시면 댓글 부탁드려요!)
    장기적으로는 CUBRID에서 지원하게 수정해야겠네요.

    select case
                when to_number(to_char(sysdate, 'd')) between 4 and 7 then sysdate + CAST(10 - to_number(to_char(sysdate, 'd')) AS int)
                else sysdate +CAST(3-to_number(to_char(sysdate, 'd')) AS int) end
    from db_root


    select sysdate + 3 from db_root -- OK

    select sysdate + to_number('3') from db_root -- ERROR

    select sysdate + CAST(to_number('3') AS int) from db_root -- OK

    select sysdate + CAST('3' AS int) from db_root -- OK

  • ?
    웁쓰 2009.07.29 21:02
    현재 버전에서 CUBRID 묵시적 형변환 (Implicit Type Conversion) 이 다른 DBMS 보다 좀 더 strict  합니다.
    개선되어야 하는 부분이 맞구요. 계속 사용하실때 Oracle에서 되던 연산이 수행되지 않을수도 있습니다.

    아래 링크를 통해서 확인 가능 합니다.

    CUBRID Data Type 형변환 matrix
    http://www.cubrid.com/online_manual/cubrid_814/syntax/syntax_operator_cast.htm
    Oracle Data Type 형변환 matrix
    http://download.oracle.com/docs/cd/B28359_01/server.111/b28286/sql_elements002.htm#i55214

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 51
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
734 Java VM library is not found 오류 발생 1 mon 2020.09.22 587
733 insert all 1 Babiyo 2020.09.22 235
732 큐브리드 매니저 테이블 정보 확인 안되는 문제 4 bchlim 2020.09.23 218
731 HA 구성시 갑자기 master - slave 가 전환됩니다. 1 nagh 2020.10.05 184
730 마이그레이션 시 성능 문의 file 모모 2020.10.06 81
729 큐브리드 매니져 erd 볼때 not null 값은 갚 못보나요? 1 덴드로비움 2020.10.06 400
728 쿼리 실행 속도 의문 1 하하 2020.10.06 492
727 마이그레이션중 to_date 문의 1 하하 2020.10.06 81
726 인덱스 scan 문의합니다 1 모모 2020.10.07 202
725 utf-8로 데이터베이스를 구성했는데 컬럼의 데이터값이 byte를 측정하려면 어떻하요? 1 덴드로비움 2020.10.07 230
724 서브쿼리의 max값 3 하하 2020.10.08 1200
723 설치 관련 문의 1 file 하바리 2020.10.12 76
722 cmt 실행 에러 진문 드려요 4 덴드로비움 2020.10.12 656
721 트리거에 여러개의 execute 문을 사용할 수 있는지요? 1 푸르른하늘 2020.10.13 363
720 큐브리드 메니저 접속시 오류(..최신 버전의 메니저 클라이언트를 이용해주세요) 1 file 푸르른하늘 2020.10.13 185
719 CUBRID_ADO_NET_4_5_10_2_latest.zip 를 적용하였을때 connection 오류 3 file 푸르른하늘 2020.10.13 206
718 보관로그(아카이브로그) 자동삭제 질문 드립니다 1 T군 2020.10.13 399
717 ORACLE_STYLE_EMPTY_STRING 설정 값에 의한 TRIM 처리에 대한 문의 1 zeroradish 2020.10.14 102
716 무슨 에러인지 문의 드립니다. 2 file Philip Park 2020.10.15 88
715 HA 실행시 발생하는 에러 1 file Philip Park 2020.10.15 128
Board Pagination Prev 1 ... 159 160 161 162 163 164 165 166 167 168 ... 200 Next
/ 200

Contact Cubrid

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