oracle regexp_instr,正则表达式之REGEXP_INSTR

这个表达式包含五个子表达式,顺序如下:“abcdefghi”,“abcdef”,“abc”,“de”和“678”。如果subexpr为零,那么返回匹配pattern中整个字符串的子字符串位置。如果的subexpr大于零,则返回匹配对应于子表达式编号的subexpr的子字符串位置。如果pattern不包含subexpr子表达式,函数返回0。一个空的subexpr值返回NULL。Subexpr默认值是零。

示例

下面的例子中检查字符串,搜索出现的一个或多个非空字符。Oracle从第一个字符开始搜索,并返回第六次出现一个或多个非空字符的的起始位置(默认设置)。

SELECT

REGEXP_INSTR('500 Oracle Parkway, Redwood Shores, CA',

'[^ ]+', 1, 6) "REGEXP_INSTR"

FROM DUAL;

REGEXP_INSTR

------------

37

下面的例子中检查字符串,寻找以s,r或p开头,大小写不限,并且紧跟着任意6字母字符的子字符串。Oracle从第3个字符开始搜索,返回第2个符合要求的子字符串之后的字符位置。

SELECT

REGEXP_INSTR('500 Oracle Parkway, Redwood Shores, CA',

'[s|r|p][[:alpha:]]{6}', 3, 2, 1, 'i') "REGEXP_INSTR"

FROM DUAL;

REGEXP_INSTR

------------

28

下面的例子使用subexpr参数来搜索pattern中特定的子表达式。第一条语句返回的是源字符串中第一个子表达式,即“123”,第一次出现的位置:

SELECT REGEXP_INSTR('1234567890', '(123)(4(56)(78))', 1, 1, 0, 'i', 1)

"REGEXP_INSTR" FROM DUAL;

REGEXP_INSTR

-------------------

1

以下语句返回的是源字符串中第二个子表达式,即“45678”,第一次出现的位置:

SELECT REGEXP_INSTR('1234567890', '(123)(4(56)(78))', 1, 1, 0, 'i', 2)

"REGEXP_INSTR" FROM DUAL;

REGEXP_INSTR

-------------------

4

以下语句返回的是源字符串中第四个子表达式,即“78”,第一次出现的位置:

SELECT REGEXP_INSTR('1234567890', '(123)(4(56)(78))', 1, 1, 0, 'i', 4)

"REGEXP_INSTR" FROM DUAL;

REGEXP_INSTR

-------------------

7

备注:关于match_param

match_param是一个文本文字,它可以让你改变函数的默认匹配行为。可以指定一或多个值用于match_param,match_param 变量支持下面几个值:

‘i’ 用于不区分大小写的匹配

‘c’ 用于区分大小写的匹配

‘n’ 允许句点(.)作为通配符去匹配换行符。如果省略该参数,则句点将不匹配换行符

‘m’ 将源字符串视为多行。即Oracle 将^和$分别看作源字符串中任意位置任何行的开始和结束,而不是仅仅看作整个源字符串的开始或结束。如果省略该参数,则Oracle将源字符串看作一行。

‘x’ 忽略空格字符。默认情况下,空格字符与自身相匹配。

如果为match_param

指定了多个相互矛盾的值,那么Oracle

使用最后一个值。例如你指定了'ic',那么Oracle将使用区分大小写的匹配。如果你指定了上述定义之外的字符,Oracle将会报错。如果你忽略了match_param,那么:

根据NLS_SORT参数的值来决定是否区分大小写

句点(.)不去匹配换行符

源字符串视为一行

hoegh

15.12.14

-- The End --

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值