Mis*_*lup 7 regex oracle oracle10g
如果我使用下面的表达式,结果应为1.
regexp_instr('500 Oracle Parkway, Redwood Shores, CA','[[:digit:]]')
Run Code Online (Sandbox Code Playgroud)
有没有办法让这个查找字符串中的最后一个数字?如果我要查找上例中的最后一个数字,它应该返回3.
Jus*_*ave 10
如果您使用的是11g,则可以regexp_count用来确定字符串中存在模式的次数并将其输入到字符串中regexp_instr
regexp_instr( str,
'[[:digit:]]',
1,
regexp_count( str, '[[:digit:]]')
)
Run Code Online (Sandbox Code Playgroud)
但是,由于你是10g,最简单的选择可能是反转字符串并减去从字符串长度中找到的位置
length(str) - regexp_instr(reverse(str),'[[:digit:]]') + 1
Run Code Online (Sandbox Code Playgroud)
两种方法都应该在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
Run Code Online (Sandbox Code Playgroud)