HotCoffeeCup 2017-06-01 01:23 采纳率: 50%
浏览 1242

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条回答

  • 全栈极简 博客专家认证 2017-06-01 01:30
    关注

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

    评论

报告相同问题?

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?