PLSQL_基础系列1_正则表达REGEXP_LIKE / SUBSTR / INSTR / REPLACE

2014-11-30 BaoXinjian

一、摘要



ORACLE中的支持正则表达式的函数主要有下面四个:

1 REGEXP_LIKE :与LIKE的功能相似

2 REGEXP_INSTR :与INSTR的功能相似

3 REGEXP_SUBSTR :与SUBSTR的功能相似

4 REGEXP_REPLACE :与REPLACE的功能相似

它们在用法上与Oracle SQL 函数LIKE、INSTR、SUBSTR 和REPLACE 用法相同。

二、调用格式



1. 格式:

REGEXP_INSTR (source_string, pattern
               [, position
                  [, occurrence
                     [, return_option
                        [, match_parameter ]
                     ]
                  ]
               ]
             )

2. 参数说明:

(1). source_string:输入的字符串

(2). pattern:正则表达式

(3). position:标识从第几个字符开始正则表达式匹配。(默认为1)

(4). occurrence:标识第几个匹配组。(默认为1)

(5). return_option:0——返回第一个字符出现的位置。1:pattern下一个字符起始位置。

(6). match_parameter:取值范围

  • i:大小写不敏感;
  • c:大小写敏感;
  • n:点号 . 不匹配换行符号;
  • m:多行模式;
  • x:扩展模式,忽略正则表达式中的空白字符。

三、元字符和字符簇



1. 特殊字符

‘^‘ 匹配输入字符串的开始位置,在方括号表达式中使用,此时它表示不接受该字符集合。

‘$‘ 匹配输入字符串的结尾位置。如果设置了 RegExp 对象的 Multiline 属性,则 $ 也匹配 ‘\n‘ 或 ‘\r‘。

‘.‘ 匹配除换行符 \n之外的任何单字符。

‘?‘ 匹配前面的子表达式零次或一次。

‘*‘ 匹配前面的子表达式零次或多次。

‘+‘ 匹配前面的子表达式一次或多次。

‘( )‘ 标记一个子表达式的开始和结束位置。

‘[]‘ 标记一个中括号表达式。

‘{m,n}‘ 一个精确地出现次数范围,m=<出现次数<=n,‘{m}‘表示出现m次,‘{m,}‘表示至少出现m次。

‘|‘ 指明两项之间的一个选择。例子‘^([a-z]+|[0-9]+)$‘表示所有小写字母或数字组合成的字符串。

\num 匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。

‘\‘ 转义符。

2. 字符簇

[[:alpha:]] 任何字母。

[[:digit:]] 任何数字。

[[:alnum:]] 任何字母和数字。

[[:space:]] 任何白字符。

[[:upper:]] 任何大写字母。

[[:lower:]] 任何小写字母。

[[unct:]] 任何标点符号。

[[:xdigit:]] 任何16进制的数字,相当于[0-9a-fA-F]。

3. 各种操作符的运算优先级

\ 转义符

(), (?, (?=), [] 圆括号和方括号

*, +, ?, {n}, {n,}, {n,m} 限定符

^, $, \anymetacharacter 位置和顺序

| “或”操作

四、案例



1. 创建测试数据

CREATE TABLE test (mc VARCHAR2 (60));

BEGIN
   INSERT INTO test VALUES   (‘112233445566778899‘);
   INSERT INTO test VALUES   (‘22113344 5566778899‘);
   INSERT INTO test VALUES   (‘33112244 5566778899‘);
   INSERT INTO test VALUES   (‘44112233 5566 778899‘);
   INSERT INTO test VALUES   (‘5511 2233 4466778899‘);
   INSERT INTO test VALUES   (‘661122334455778899‘);
   INSERT INTO test VALUES   (‘771122334455668899‘);
   INSERT INTO test VALUES   (‘881122334455667799‘);
   INSERT INTO test VALUES   (‘991122334455667788‘);
   INSERT INTO test VALUES   (‘aabbccddee‘);
   INSERT INTO test VALUES   (‘bbaaaccddee‘);
   INSERT INTO test VALUES   (‘ccabbddee‘);
   INSERT INTO test VALUES   (‘ddaabbccee‘);
   INSERT INTO test VALUES   (‘eeaabbccdd‘);
   INSERT INTO test VALUES   (‘ab123‘);
   INSERT INTO test VALUES   (‘123xy‘);
   INSERT INTO test VALUES   (‘007ab‘);
   INSERT INTO test VALUES   (‘abcxy‘);
   INSERT INTO test VALUES   (‘The final test is is is how to find duplicate words.‘);

   COMMIT;
END;

2. 案例 REGEXP_LIKE

{}的意思是连续几个的匹配上面的sql的意思是开头有1个到3个连续a

有连续3个a

以a开头以e结尾的字符之所以有.是因为如果写成^a*e$就变成以a开头中间都是a以e结尾的字符拉 *的意思是匹配它前面的字符
^ab*e$可否查出以a开头以e结尾的字符呢?
答案是否定的因为*虽然是可以匹配前面的b0次或者多次但是它也仅仅是匹配
以a开头中间可以有b并且都是b,或者中间没有字符,以e结尾的字符.
‘^[[:alpha:]]+$‘的意思是以字母从开头到结尾都包含字母的字符

小写字母或者数字开头的字符

小写字母开头的字符

"^"就是一个有多种意义的字符元,主要看语意环境如果"^"是字符列中的第一个字符,就表示对这个字符串取反,因此, [^[:digit:]]就是表示查找非数字的模式即字符中不都是数字

以非数字开头的字符

3. 案例 REGEXP_INSTR

4. 案例 REGEXP_SUBSTR

5. 案例 REGEXP_REPLACE

参考: http://blog.sina.com.cn/s/blog_56cacf83010005aw.html

Thanks and Regards

时间: 2024-10-03 09:00:29

PLSQL_基础系列1_正则表达REGEXP_LIKE / SUBSTR / INSTR / REPLACE的相关文章

PLSQL_基础系列1_正则表达式regexp_like/substr/instr/replace

2014-11-30 BaoXinjian 一.摘要 ORACLE中的支持正则表达式的函数主要有下面四个: 1 REGEXP_LIKE :与LIKE的功能相似 2 REGEXP_INSTR :与INSTR的功能相似 3 REGEXP_SUBSTR :与SUBSTR的功能相似 4 REGEXP_REPLACE :与REPLACE的功能相似 它们在用法上与Oracle SQL 函数LIKE.INSTR.SUBSTR 和REPLACE 用法相同. 二.调用格式 1. 格式: REGEXP_INSTR

PLSQL_基础系列8_操作符标LPAD / TRUNC / DECODE / TRIM / INSTR

2014-12-09 BaoXinjian 一.字符函数 1. LOWER (strexp) - 返回字符串,并将所有的字符小写. select lower('ABCDE') from dual 2. UPPER (strexp)     返回字符串,并将所有的字符大写. select upper('abcdf') from dual 3.INITCAP(strexp)    将字符串的(每个单词的)第一个字母变为大写,后面的小写; select initcap(' source fore')

PLSQL_基础系列2_分组函数GROUP BY / ROLLUP / CUBE

2014-11-30 BaoXinjian 一.摘要 ROLLUP 运算符生成的结果集类似于 CUBE 运算符生成的结果集. 1. 下面是 CUBE 和 ROLLUP 之间的具体区别: CUBE 生成的结果集显示了所选列中值的所有组合的聚合. ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合. 2. ROLLUP 优点: (1). ROLLUP 返回单个结果集,而 COMPUTE BY 返回多个结果集,而多个结果集会增加应用程序代码的复杂性. (2). ROLLUP 可以在服务器游

PLSQL_基础系列4_时间间隔INTERVAL

2014-12-08 BaoXinjian 一.摘要 INTERVAL数据类型用来存储两个时间戳之间的时间间隔. 可以指定years and months,或者days,hours,minuts,seconds之间的间隔. ORACLE支持两种INTEVAL类型,它们分别是YEAR TO MONTH和DAY TO SECOND. 每个类型都包含leading field和trailing field.主参数定义要被计算的date或者time,副参数定义最小增长量 二.语法 1. Oracle语法

PLSQL_基础系列3_合并操作UNION / UNION ALL / MINUS / INTERSET

2014-11-30 BaoXinjian 一.摘要 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到Union或者Union All关键字.Union(或称为联合)的作用是将多个结果合并在一起显示出来. Union和Union All的区别是,Union会自动压缩多个结果集合中的重复结果,而Union All则将所有的结果全部显示出来,不管是不是重复. Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序: Union All:对两个结果集进行

PLSQL_基础系列9_时间戳Timestamp

2013-11-09 BaoXinjian 1. 获取系统时间的语句(ssxff6获取小数点后面六位) select sysdate,systimestamp,to_char(systimestamp, 'yyyymmdd hh24:mi:ssxff6'), to_char(systimestamp, 'yyyymmdd hh24:mi:ss.ff6') from dual; 2. 字符型转成timestamp select to_timestamp('2011-09-14 12:52:42.1

PLSQL_基础系列7_插入方式Pivoting / Unconditional / Conditional ALL / Conditional FIRST INSERT

2014-12-08 BaoXinjian 一.摘要 Oracle Insert的多种方式 1. standard insert 1. pivoting Insert 2. unconditional insert 3. conditional all insert / conditional first insert 二.标准Insert - 单表单行插入 标准Insert -- 单表单行插入 1. 语法: INSERT INTO table [(column1,column2,...)] V

PLSQL_基础系列5_视图控制WITH CHECK OPTION

2014-12-09 BaoXinjian 一.摘要 通过有with check option选项的视图操作基表(只是面对单表,对连接多表的视图正在寻找答案),有以下结论: 首先视图只操作它可以查询出来的数据,对于它查询不出的数据,即使基表有,也不可以通过视图来操作. 1. 对于update, 有with check option,要保证update后,数据要被视图查询出来 2. 对于delete, 有无with check option都一样 3. 对于insert, 有with check

PLSQL_基础系列6_判断操作NVL / NULLIF / COALESCE / NVL2

2014-12-08 BaoXinjian 一.摘要 下列函数可用于任何数据类型,且适合使用空值的场合:NVL (expr1, expr2)NVL2 (expr1, expr2, expr3)NULLIF (expr1, expr2)COALESCE (expr1, expr2, ..., exprn) 二.案例 - NVL 1. NVL函数的格式如下:NVL(expr1,expr2) 2. 含义是:如果oracle第一个参数为空那么显示第二个参数的值,如果第一个参数的值不为空,则显示第一个参数