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

时间:2012-03-18 03:06:59

标签: regex oracle oracle10g

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

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

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

2 个答案:

答案 0 :(得分:10)

如果您使用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, Redwood Shores, 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:]]',1,REGEXP_COUNT(STR,'[[:DIGIT:]]'))
-----------------------------------------------------------------
                                                     3
                                                                3

答案 1 :(得分:1)

另一种省力的解决方案是

SELECT regexp_instr('500 Oracle Parkway, Redwood Shores, CA','[^[:digit:]]*$')-1 
FROM dual;

这可以读作..找到字符串末尾的非数字。并减1.这将给出字符串中最后一位的位置..

REGEXP_INSTR('500ORACLEPARKWAY,REDWOODSHORES,CA','[^[:DIGIT:]]*$')-1
--------------------------------------------------------------------
                                                                   3 

我认为这就是你想要的。

(在11g上测试)