ORACLE中的支持正则表达式的函数主要有下面四个:
1,REGEXP_LIKE :与LIKE的功能相似
2,REGEXP_INSTR :与INSTR的功能相似
3,REGEXP_SUBSTR :与SUBSTR的功能相似
4,REGEXP_REPLACE :与REPLACE的功能相似
^ 匹配字符串的开头位置。
$ 匹配支付传的结尾位置。
* 匹配该字符前面的一个字符0次,1次或者多次出现。例如52*oracle 可以匹配 5oracle,52oracle,522oracle,5222oracle等等。
+ 匹配该字符前面的一个字符1次或者多次出现。例如52+oracle 可以匹配 52oracle,522oracle,5222oracle等等
? 匹配该字符前面的一个字符0次或1次或者多次出现。例如52?oracle 只能匹配5oracle,52oracle等等
{n} 匹配一个字符串n次,n为正整数。例如:hel{2}o 所匹配的是hello
{n,m} 匹配一个字符串至少n次,至多m次。其中n和m都是整数。
. 匹配除了null之外的任何单个字符串
(pattern) 这个是用来匹配指定模式的一个子表达式
x|y 匹配x或者y,其中x和y是一个或者多个字符
[abc] 匹配括号中的任意一个字符。例如:[ab]bc可以匹配abc和bbc
[a-z] 匹配指定范围内的任意字符串。例如[A-G]hi可以匹配Ahi至Ghi
[::]指定一个字符类,可以匹配该类中的任意字符 这里的字符类包括:
[:alphanum:] 可以匹配字符0-9、A-Z、a-z
[:alpha:]可以匹配字符A-Z、a-z
[:blank:]可以匹配空格或者tab键
[:digit:]可以匹配数字 0-9
[:gragh:]可以匹配非空字符
[:punct:]可以匹配. , ” ‘等标点符号。
[:upper:]可以匹配字符A-Z
[:lower:]可以匹配字符a-z
各种操作符的运算优先级
\转义符
(), (?:), (?=), [] 圆括号和方括号
*, +, ?, {n}, {n,}, {n,m} 限定符
^, $, anymetacharacter 位置和顺序
|
*/
字符串’^198[0-9]$’可以匹配‘1980-1989’,如果希望统计出公司那些员工是80年~89年入职的,就可以使用如下的SQL语句:
select * from emp e whereregexp_like(to_char( e.hiredate,'yyyy'),'^198[0-9]$');
substr和instr套嵌使用就可以实现indexof类似功能
eg:园林专业优先电话:07713212335-803 取电话号码,通过 '电话:' 做为分隔。
select substr('园林专业优先电话:07713212335-803',instr('园林专业优先电话:07713212335-803','电话:')+3,20) from dual;
--查询@TV 后面是否全部都是数字
select t.acc_nbr,t.main_acc_nbr from user t
where regexp_like(substr(t.main_acc_nbr,instr(UPPER(t.main_acc_nbr),'@TV')+3,20),'^[0-9]+[0-9]*$')
and t.acc_nbr='pay001';
--查询@TV 后面是否全部都是数字
select t.acc_nbr,t.main_acc_nbr from user t
where regexp_like(substr(t.main_acc_nbr,instr(UPPER(t.main_acc_nbr),'@TV')+3,20),'^[[:digit:]]+$')
and t.acc_nbr='pay001';
--查询@TV 后面是否全部都是数字
select t.main_acc_nbr from user t
--排除没有@TV的账号
where to_number(instr(t.main_acc_nbr,'@TV')) != 0
--排除账号@TV 后面是否全部都是数字
and regexp_like(substr(t.main_acc_nbr,instr(UPPER(t.main_acc_nbr),'@TV')+3,20),'^[0-9]+[0-9]*$') ;
参考:
oracle 字符函数相关http://wenku.baidu.com/view/5a76e0c58bd63186bcebbcb1.html
http://blog.163.com/liu_yang1234/blog/static/2447431020112290109559/
http://blog.sina.com.cn/s/blog_53636a020100f93i.html