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;

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

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