Oracle中的Substr( )函数和Instr()函数

1.Substr( )

格式:SUBSTR(s,m,n)

SUBSTR(s,m,n)用来获取指定的字符串。其中参数s代表字符串,m代表截取的位置,n代表截取长度。m为正数,代表截取从左往右的第m位开始,m为负数,代表截取从右往左的第n位开始,m为0是与m为1等效。

例如:

SELECT SUBSTR ('这是一篇数据库知识文章',3,7),SUBSTR('这是一篇数据库知识文章',-3,7) FROM DUAL;

返回结果如下:

2.字符串搜索函数INSTR(S,X)

instr函数是用来返回要截取的字符串在源字符串中的位置,返回值就是截取的长度。其中S是源字符串, X是目标字符串。

例如:

SELECT INSTR('这是一篇数据库知识文章','数' ) FROM DUAL;

返回结果如下:

3.Substr( )函数和Instr()函数组合

select Substr('843|0|17.76|0|微信支付||', 1, Instr('843|0|17.76|0|微信支付||', '||')-1)from dual;

这里用'|'作为分隔符,通过Instr()函数获取截取的长度,再用Substr( )函数获取想要的字符串,'|'的位置默认为字符串中第一次出现'|'的位置。

通过这样组合来获取想要的字符串,比如要获取"微信支付":

 select Substr('843|0|17.76|0|微信支付', -4, Instr('843|0|17.76|0|微信支付', '|') ) from dual;

当然,如果想定位到最后'|'的位置,获取它后面的字符串,还可以这样做:

 SELECT Reverse(Substr(Reverse('843|0|17.76|0|微信支付'), 1, Instr(Reverse('843|0|17.76|0|微信支付'), '|') - 1))FROM dual;

Reverse()是反转函数,用来进行反向查找。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值