永发信息网

刚学习使用db2,在创建自定义函数时遇到一个问题,函数代码如下

答案:2  悬赏:40  手机版
解决时间 2021-04-09 18:03
  • 提问者网友:我的未来我做主
  • 2021-04-08 18:55
create or replace function F_GETDATE_BY_Q(p_quarter integer)
language sql
specific F_GETDATE_BY_Q
returns varchar(8)
begin atomic
declare v_result varchar(8);
declare v_current_date varchar(8);
declare v_date_of_quarter_end varchar(8);
declare v_date_of_quarter_begin varchar(8);

set v_current_date = (select to_char(current date,'YYYYMMDD') from sysibm.sysdummy1);
set v_date_of_quarter_end = (select max(biz_date) from f_com_com_date where year = year(current date) and q = p_quarter);
set v_date_of_quarter_begin = (select min(biz_date) from f_com_com_date where year = year(current date) and q = p_quarter);

if (v_current_date < v_date_of_quarter_begin) then
set v_result = '19000230';
else if (v_current_date >= v_date_of_quarter_begin and v_current_date <= v_date_of_quarter_end) then
set v_result = v_current_date;
else if (v_current_date > v_date_of_quarter_end) then
set v_result = v_date_of_quarter_end;
end if;

return v_result;
end

>[错误] 脚本行:24-24 -------------------------------------
An unexpected token "END-OF-STATEMENT" was found following "end". Expected tokens may include: "JOIN ".. SQLCODE=-104, SQLSTATE=42601, DRIVER=3.53.71

麻烦大家给看下是哪儿出错了,先谢了
最佳答案
  • 五星知识达人网友:北城痞子
  • 2021-04-08 19:04
你是怎么执行的脚本呢? 使用db2 -td# proc.sql这样执行的吗?
那样的话,你需要在procedure的末尾end的后面加一个‘#’符号,表示结束。

如下:
return v_result;
end #
全部回答
  • 1楼网友:持酒劝斜阳
  • 2021-04-08 19:37
atomic是将该部分程序块指定为一个整体,其中任何一个语句失败,则整个程序块都相当于没做,包括包含在atomic块内的已经执行成功的语句也相当于没做,有点类似于transaction。 这个 atomic 一般是使用在 触发器上面的。 而你的是 自定义 函数。 不更新任何数据的, 加 atomic 没有意义啊!
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯