正则表达式regexp_like regexp_replace regexp_substr
regexp_likeregexp_like函数的基本构成是:
regexp_like(x,pattern[,match_option])
其基本功能是在x中查找pattern,如果能找到返回true否则返回false,这里的可选参数match_option可以有如下几种形式:'c'表明进行匹配时区分大小写(这也是默认选项)。
'i'表明在匹配时不区分大小写。
'n'表明允许使用匹配任何字符串的元数据,即'.'。
'm'将x作为一个包含多行的字符串。
以下是两个关于regexp_like的例子:
这个例子是寻找员工中的80后的员工。
select*fromempwhereregexp_like(to_char(birthdate,'yyyy'),'^198[0-9]$');
这个例子是寻找名字是以'M'或者'm'打头的那些员工的名字
select*fromempwhereregexp_like(ename,'^j','i')数regexp_replace和regexp_substr。
regexp_replace函数和regexp_substr函数的功能类似与字符函数replace和substr,只是这里的应用更加灵活,可以一下子匹配一系列的结果,而原来的函数只能一下子匹配一个固定的字符换。
具体来讲:
的意义是找到于给定模式匹配的字符串并用其他的字符串来替代。
其原型是:regexp_replace(x,pattern[,replace_string[,start[,occurence[match_option]]]])
每个参数的意思分别是:
x待匹配的函数
pattern正则表达式元字符构成的匹配模式
replace_string替换字符串
start开始位置
occurence匹配次数
match_option匹配参数,这里的匹配参数和regexp_like是完全一样的,可参考前面的一篇文章。
举例来讲:
selectregexp_replace('helloeverybody,mayIhaveyourattentionplease?','b[[:alpha:]]${3}','one')fromdual将会返回结果:
helloeveryone,mayIhaveyourattentionplease?
而regexp_substr函数的意义找出与给定模式匹配的字符串并返回,
其原型是:regexp_substr(x,pattern[,start[,occurence[match_option]]])
这里各参数的意义与前面的函数regexp_replace的含义是一样做的。
regexp_substr的例子如下:
selectregexp_substr('Iloveoracleverymuch','o[[:alpha:]]${4}')fromdual;
这里将会匹配出结果:
oracle来。这也是这个函数的返回结果。