oracle中字符串连接以及在函数中常见问题的解决方法

csdn 标签:
如下函数,用来查出名字相似于某字符串
create or replace function f_GetUsers(key in varchar2, p_cursor out pkg_test.myrctype) return number is Result number; begin open p_cursor for SELECT * FROM Accounts_Users where TrueName like '%'+key+'%' order by UserID; Result := 0; return(Result); end; /

编译成功,测试的时候也没有发现错误,但是到了真正的生产环境的时候,

报错误 ORA-01722: 无效数字 很莫名

后来查阅网络

发现ORACLE 的字符串连接必须用||符号的,然后修改测试 如下

create or replace function f_GetUsers(varkey in varchar2,
                                               p_cursor out pkg_test.myrctype)
  return number is
  Result number;
begin
  open p_cursor for
   SELECT * FROM Accounts_Users where TrueName like '%'||varkey||'%' order by UserID;
  Result := 0;
  return(Result);
end;

编译通过

测试数据,也没有问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值