oracle instr 实现拆分,oracle字段根据字符串拆分,用subStr()和inStr()进行拆分

今天进行字符串根据字符拆分的sql的编写,刚开始是按照split的方式进行处理的,Oracle是没有现成的split函数的,需要在网上找。网上大多是处理之后会变成collection的,结果是不好处理的,比如拆分之后,要把拆分出来的前半部分和后半部分做成两列,第一列可以根据rownum=1进行处理,第二列开始就不行了。

所以考虑用subStr()和inStr()进行拆分,先用inStr()查出符号的位置,再通过subStr()进行截取,如下:

select substr('前/后',0,instr('前/后','/',1,1)-1) first

,substr('前/后',instr('前/后','/',1,1)+1,length('前/后')) lastfrom dual

执行结果:

show-42041.html

a603bad3557c9afb09a3fbe54b70fd4c.png

=================================================================

INSTR(源字符串, 要查找的字符串, 从第几个字符开始找, 要找到第几个匹配的序号)

INSTR(C1,C2,I,J)

在一个字符串中搜索指定的字符,返回发现指定的字符的位置;

C1 被搜索的字符串

C2 希望搜索的字符串

I 搜索的开始位置,默认为1

J 出现的位置,默认为1

===================================================================

substr函数的用法:

取得字符串中指定起始位置和长度的字符串   substr( string, start_position, [ length ] )

---------------------

作者:J梦幻

来源:CSDN

原文:https://blog.csdn.net/panlanghao/article/details/74991982

版权声明:本文为博主原创文章,转载请附上博文链接!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值