Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
 Linux 64bit
CUBRID Ver.
   9.3.9
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java

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


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

AS_IS오라클 쿼리에서 CUBRID로 변경중입니다.

SELECT
         S_DATE
         ,R_DATE
        , TO_CHAR(TO_DATE(R_DATE, 'YYYYMMDDHH24MISS'), 'YYYY.MM.DD') rDate
        , ROUND(SYSDATE - TO_DATE(NVL(S_DATE, R_DATE), 'YYYYMMDDHH24MISS')) diff
           FROM T_ARTICLE


에서


SELECT

         S_DATE
        , R_DATE
        , TO_CHAR(TIMESTAMP(R_DATE, 'YYYYMMDDHH24MISS'), 'YYYY.MM.DD') rDate
      , ROUND(SYSDATE - TO_CHAR(TIMESTAMP(NVL(S_DATE, R_DATE), 'YYYYMMDDHH24MISS'))) diff

       FROM T_ARTICLE


변경하였습니다.


  , ROUND(SYSDATE - TO_CHAR(TIMESTAMP(NVL(S_DATE, R_DATE), 'YYYYMMDDHH24MISS'))) diff


이부분에서 변경이 안되고 있습니다.


S_DATE, R_DATE의 type는 varchar입니다.





  • ?
    권호일 2019.02.22 15:41
    아래와 같이 해 보시기 바랍니다.

     , ROUND(SYSDATETIME  - TO_CHAR(TIMESTAMP(NVL(S_DATE, R_DATE), 'YYYYMMDDHH24MISSFF'))) diff
     
    유의사항은 기존의 오라클은 날짜 단위의 연산을 하고, 큐브리드는 밀리세컨드 단위의 연산을 합니다. 

  • ?
    세오7 2019.02.25 10:22
    댓글과 같이 해보았으나 Conversion error in timestamp format 에러가 나네요. ㅠ
  • ?
    권호일 2019.02.25 14:04
    SELECT ROUND(SYSDATETIME - TO_CHAR(TIMESTAMP(NVL( '20190225121212', '20190225121212' ) , 'YYYYMMDDHH24MISSFF')))
    FROM db_root ;

    CUBRID에서 위와 같이 SQL문을 실행하면 정상 실행 됩니다.

    S_DATE, R_DATE 컬럼의 데이타가 위의 예제와 같은 포맷으로 작성되어 있는지 확인 해주세요 ( 컬럼값 예시 : '20190225121212', '20190225121212' )
  • ?
    권호일 2019.02.25 15:41
    TO_CHAR 함수는 불필요해 보여서 제거하고 테스트 해 보았습니다.
    아래 결과를 참조하세요.

    아래 결과는 NULL로 처리 됩니다.
    SELECT ROUND(SYSDATETIME - TIMESTAMP( NVL( NULL, NULL ) , 'YYYYMMDDHH24MISSFF') ) FROM db_root

    아래의 결과는 오류가 발생합니다. ( Conversion error in timestamp format. )
    SELECT ROUND(SYSDATETIME - TIMESTAMP( NVL( NULL, '' ) , 'YYYYMMDDHH24MISSFF') ) FROM db_root


    위 테스트 결과를 보았듯이 R_DATE 컬럼의 값이 ''( empty string)일 경우 형변환 오류가 발생합니다.

  1. SQLGate for CUBRID 영구 무료 라이선스 제공

  2. 브로커(CAS)수 질문드립니다!

  3. 데이터 이관 문의입니다.

  4. No Image 24May
    by 네오랜덤
    2023/05/24 by 네오랜덤
    Views 176 

    8.4.4 charset. Collation 확인 방법

  5. 8.4.4버젼 charset 확인

  6. 쿼리 속도 차이 질문

  7. spring boot 에서 HikariPool-1 - Driver does not support get/set network timeout for connections. (java.lang.UnsupportedOperationException) 질문 드립니다.

  8. cci 프로그래밍에서 DB LINK 관련 문의

  9. 큐브리드 매니저 실행이 오류

  10. ddl 추출

  11. 하나의 쿼리에서 복수 테이블 업데이트 방법 문의

  12. cubrid driver 설치 문의

  13. 큐브리드 매니저 접속 이 안됩니다. 확인 요청 드립니다.

  14. Fk값 가져오기

  15. 서버 메모리 교체 및 ha 상 데이터 삭제 절차

  16. java stored procedure 에 loadjava 로 jar 파일 로드 시 java.lang.ClassNotFoundException 에러 문의

  17. Cubrid stored procedure 스케쥴 등록 형식

  18. 암호화 함수 MDB_ENC 질문입니다

  19. No Image 14Apr
    by 부패방지운영팀
    2023/04/14 by 부패방지운영팀
    Views 242  Replies 1

    auto_increment 추가 방법 문의

  20. CUBRID 사용자 계정 생성 관련 문의

  21. order by 이후 rownum이 의도와 다르게 찍힙니다.

Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 11 ... 199 Next
/ 199

Contact Cubrid

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