加入收藏 | 设为首页 | 会员中心 | 我要投稿 常州站长网 (https://www.0519zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

使用regexp_instr获取字符串中的最后一个数字

发布时间:2021-05-21 09:36:54 所属栏目:百科 来源:网络整理
导读:如果我使用以下表达式,结果应为1. regexp_instr('500 Oracle Parkway,Redwood Shores,CA','[[:digit:]]') 有没有办法让这个查找字符串中的最后一个数字?如果我要查找上例中的最后一个数字,它应该返回3. 如果您使用11g,则可以使用regexp_count来确定字符串

如果我使用以下表达式,结果应为1.

regexp_instr('500 Oracle Parkway,Redwood Shores,CA','[[:digit:]]')

有没有办法让这个查找字符串中的最后一个数字?如果我要查找上例中的最后一个数字,它应该返回3.

如果您使用11g,则可以使用regexp_count来确定字符串中存在模式的次数并将其提供给regexp_instr
regexp_instr( str,'[[:digit:]]',1,regexp_count( str,'[[:digit:]]')
            )

但是,由于你是10g,最简单的选择可能是反转字符串并减去从字符串长度中找到的位置

length(str) - regexp_instr(reverse(str),'[[:digit:]]') + 1

两种方法都应该在11g

SQL> ed
Wrote file afiedt.buf

  1  with x as (
  2    select '500 Oracle Parkway,CA' str
  3      from dual
  4  )
  5  select length(str) - regexp_instr(reverse(str),'[[:digit:]]') + 1,6         regexp_instr( str,7                       '[[:digit:]]',8                       1,9                       regexp_count( str,'[[:digit:]]')
 10                     )
 11*   from x
SQL> /

LENGTH(STR)-REGEXP_INSTR(REVERSE(STR),'[[:DIGIT:]]')+1
------------------------------------------------------
REGEXP_INSTR(STR,'[[:DIGIT:]]',REGEXP_COUNT(STR,'[[:DIGIT:]]'))
-----------------------------------------------------------------
                                                     3
                                                                3

(编辑:常州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读