oracle自定义函数的date类型输入问题

为什么这段代码会报错??
图片说明

原始命令是这样的
CREATE OR REPLACE FUNCTION F_EMPLEVER(HIRE_DATE date)
RETURN NUMBER
IS
V_LEVER NUMBER(1);
BEGIN
IF TO_NUMBER(TO_CHAR(HIRE_DATE,'YYYY')) >=2006 THEN
V_LEVER:=1;
RETURN (V_LEVER);
ELSIF TO_NUMBER(TO_CHAR(HIRE_DATE,'YYYY')) 2003 THEN
V_LEVER:=2;
RETURN (V_LEVER);
ELSIF TO_NUMBER(TO_CHAR(HIRE_DATE,'YYYY')) <=2003 THEN
V_LEVER:=3;
RETURN (V_LEVER);
END IF;
EXCEPTION
WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE('日期格式输入有错,应该是YYYY-MM-DD');
END;

最后,这是我被迫这样写的。

CREATE OR REPLACE FUNCTION F_EMPLEVER(HIRE_DATE VARCHAR2)
RETURN NUMBER
IS
V_LEVER NUMBER(1);
V_DATE DATE;
BEGIN
V_DATE:=TO_DATE(HIRE_DATE,'YYYY-MM-DD');
IF TO_NUMBER(TO_CHAR(V_DATE,'YYYY')) >=2006 THEN
V_LEVER:=1;
RETURN (V_LEVER);
ELSIF TO_NUMBER(TO_CHAR(V_DATE,'YYYY')) 2003 THEN
V_LEVER:=2;
RETURN (V_LEVER);
ELSIF TO_NUMBER(TO_CHAR(V_DATE,'YYYY')) <=2003 THEN
V_LEVER:=3;
RETURN (V_LEVER);
END IF;
EXCEPTION
WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE('日期格式输入有错,应该是YYYY-MM-DD');
END;

2个回答

ELSIF TO_NUMBER(TO_CHAR(V_DATE,'YYYY')) >2003 THEN 少个>
其它我试过了没有报错。

嗯嗯嗯,我找到问题所在了

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问