为什么这段代码会报错??
原始命令是这样的
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;