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

使用regexp_instr获取字符串中的最后一个数字,regex,oracle,oracle10g,Regex,Oracle,Oracle10g,如果我使用下面的表达式,结果应该是1 regexp_instr('500 Oracle Parkway, Redwood Shores, CA','[[:digit:]]') 有没有办法让它查找字符串中的最后一个数字?如果我在上面的示例中查找最后一个数字,它应该返回3。如果使用11g,可以使用regexp\u count确定字符串中存在模式的次数,并将其输入regexp\u instr regexp_instr( str, '[[:digit:]]',

如果我使用下面的表达式,结果应该是1

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

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

如果使用11g,可以使用
regexp\u count
确定字符串中存在模式的次数,并将其输入
regexp\u 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

另一个省力的解决方案是

SELECT regexp_instr('500 Oracle Parkway, Redwood Shores, CA','[^[:digit:]]*$')-1 
FROM dual;
这可以理解为。。查找字符串末尾的非数字。然后减去1。这将给出字符串中最后一个数字的位置

REGEXP_INSTR('500ORACLEPARKWAY,REDWOODSHORES,CA','[^[:DIGIT:]]*$')-1
--------------------------------------------------------------------
                                                                   3 
我想这就是你想要的


(在11g上测试)

在您的示例中没有3或1,我认为您使用[[:digit:]做了一些很时髦的事情。同样,首先你说结果应该是1,然后你说结果应该是3。请澄清。最后,在最后一个数字之后,字符串中还会有其他非数字字符吗?当我用不同的字符串运行regexp_instr(第4单元/22-24亚当斯Pde)时,结果是6,在这种情况下,这是第一个数字的索引。我在那里输入了一个错误。对于提供的示例,它应该返回1。如果我让它查找最后一个数字,它应该返回3——第二个“0”的索引。