Если бы вы использовали 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