我写的一个oracle函数(用途:取出两个标识符之间的字符串)

oracle本身自带许多了函数,但是在实际的工作中,这些函数是远远不够用,因此自定义一些函数往往使代码的执行效率更高!

需求:取出字符串'0001 1 dfds 13528221 dgdfkgdf'中第3个标识符(这个里面标识符是一个空格' ')和第4个标识符之间的字符串

create or replace function strfind
(cs        in             varchar2, --字符串
 bs        in             varchar2,--标示符
 x         in             number,  --想要取到字符串部分的第1个标示符是第几个标识符
 y         in             number)  --想要取到字符串部分的第2个标示符是第几个标识符,与前者相连
return varchar2 is
z varchar2(20);
m number;
n number;
p number;
begin
  --返回第1个标志符所在的位置
  select instr(cs,bs,1,x) into m from dual;
  --返回第2个标志符所在的位置
  select instr(cs,bs,1,y) into n from dual;
  --取得字符串z的长度
  p:=n-m-1;
  select substr(cs,m+1,p) into z from dual;
  return(z);
end strfind;
 
------测试及返回结果
需求:取出字符串'0001 1 dfds 13528221 dgdfkgdf'中第3个标识符(这个里面标识符是一个空格' ')和第4个标识符之间的字符串
---------------------------------
select strfind('0001 1 dfds 13528221 dgdfkgdf',' ',3,4) from dual
 
查询结果:
---------------------------------
13528221
 
说明:定义的参数bs最好是单个字符,可以根据实际情况对程序改动
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值