* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
Window7 32bit, Linux 64bit 등 | |
[cubrid_rel] 수행 결과 | |
[도움말]-[버전정보] 확인 | |
java, php, odbc 등 입력 |
* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 | 재현 가능한 Source와 SQL |
관련 테이블(인덱스, 키정보 포함) 정보 | CUBRID 홈 디렉토리 아래 log 디렉토리 압축 |
-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
SELECT
DECODE(LA.ARREAR_STATUS_CODE, 'paid', NVL(LA.DELAY_DAY, 0)
, DECODE(SIGN(TRUNC(SYSDATE - LA.ARREAR_LIMIT_DATE)), -1, 0, TRUNC(SYSDATE - LA.ARREAR_LIMIT_DATE))) DELAY_DAY
FROM LON_ARREAR LA;
함수들을 사용해서 출력하는 select쿼리입니다. 위의 쿼리문은 정상적으로 실행이 됩니다.
현재 이 쿼리무문장을 포함해서 뷰를 만들었습니다.
뷰는 아래와 같이 문제없이 생성됐습니다. 생략된 문장들이 있지만 문제되는 부분은 없습니다.
CREATE OR REPLACE VIEW "LON_ARREAR_V" AS
SELECT LA.LOAN_NO
, UU.USER_ID, UU.BARCODE_NO
, UU.USER_NAME, NVL(UU.TEL1, UU.TEL2) TEL, UU.MOBILE, UU.EMAIL
. . .
. . .
, DECODE(LA.ARREAR_STATUS_CODE, 'paid', NVL(LA.DELAY_DAY, 0), DECODE(SIGN(TRUNC(SYSDATE - LA.ARREAR_LIMIT_DATE)), -1, 0, TRUNC(SYSDATE - LA.ARREAR_LIMIT_DATE))) DELAY_DAY
. . .
. . .
FROM LON_ARREAR LA
, LON_LOAN LL
, USR_USER UU
, CAT_BASIC CB
, CAT_ITEM CI
WHERE LA.LOAN_NO = LL.LOAN_NO
AND LA.USER_ID = UU.USER_ID
AND LA.ITEM_NO = CI.ITEM_NO
AND CB.CONTROL_NO = CI.CONTROL_NO;
그리고 CREATE OR REPLACE VIEW "LON_ARREAR_V" AS 를 제외한 select문을 실행해보면 문제없이 실행되는 것도 확인 했습니다.
문제는 SELECT * FROM lon_arrear_v; 로 실행하면 아래와 같은 오류가 나오고 있습니다.
실행 오류 : -494
Semantic: before ' )), -1, cast( cast(0 as bigint) as numeric), cast( trunc( c...'
check syntax at 'default' select lon_arrear_v.loan_no, lon_arrear_v.user_id, lon_arrea...
아래의 문장을 제외하고 뷰를 만들면 SELECT * FROM lon_arrear_v; 가 오류나지 않고 제대로 실행 되고 있습니다.
DECODE(LA.ARREAR_STATUS_CODE, 'paid', NVL(LA.DELAY_DAY, 0)
, DECODE(SIGN(TRUNC(SYSDATE - LA.ARREAR_LIMIT_DATE)), -1, 0, TRUNC(SYSDATE - LA.ARREAR_LIMIT_DATE))) DELAY_DAY
cast문제인것 같아서 ARREAR_LIMIT_DATE의 데이터타입인 datetime으로 맞추기 위해 SYSDATE를 SYSDATETIME으로 바꿔서 연산을 해봐도 결과는 똑같습니다. 또한 CAST함수를 사용해서 datetime으로 cast를 해줘도 오류가 발생합니다.
어떤식으로 변경해야할까요??
view rewrite하면서, trucate()함수의 default 변경이 다르게 처리되어서 발생하는 오류입니다.
TRUNC(SYSDATE - LA.ARREAR_LIMIT_DATE) 형태로 된 부분을 TRUNC(SYSDATE - LA.ARREAR_LIMIT_DATE, 0) 로 변경해서 수행해보세요.