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()是反转函数,用来进行反向查找。
2515

被折叠的 条评论
为什么被折叠?



