DB2自定义函数42601异常

本文介绍了解决DB2版本V8.1.3.160补丁安装过程中遇到的问题,通过调整代码和修改文件格式成功解决了end of file reached while reading the command错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

DB2版本V8.1.3.160 补丁:18

不多说,直接上代码

 

CREATE FUNCTION MS.RENODE
 (NODECODE VARCHAR(10) )  
 RETURNS VARCHAR(10)
 LANGUAGE SQL
 NO EXTERNAL ACTION f1:
 BEGIN ATOMIC 
  DECLARE V_FCODE VARCHAR(2);
  DECLARE V_LCODE VARCHAR(8);
  SET V_FCODE =SUBSTR(NODECODE,1,2);
  SET LASTCODE = SUBSTR(NODECODE,3,8);
  IF(V_FCODE ='00') THEN  SET V_FCODE = '07';
  ELSEIF(V_FCODE ='01') THEN  SET V_FCODE = '08';
  END IF;
 RETURN V_FCODE||V_LCODE;
END;

 

以@为终结符号,就不会出现这种问题了
end@
然后在执行的时候用db2 -td@ -f xxx.sql  就ok了。
另外在执行新建表xxx.sql的时候,执行db2 -tvf crtdb.sql
出现end of file reached while reading the command
解决办法
[db2instl@localhost DB] file crtdb.sql
crtdb.sql:ISO-8859 text,with CRLF line  terminators
[db2instl@localhost DB] dos2unix crtdb.sql
dos2unix:converting file crtdb.sql to UNIX format ...
[db2instl@localhost DB] db2 -tvf crtdb.sql
successfully!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值