Oracle正则表达式函数:regexp_like、regexp_substr、regexp_instr、regexp_replace

Oracle正则表达式函数:regexp_like、regexp_substr、regexp_instr、regexp_replace

--去掉所有特殊字符,只剩字母

SELECT REGEXP_REPLACE(‘(Sam-Tomats123-=,.231+)‘,‘[^[:alpha:]]‘,‘‘) FROM dual;

Sql代码

Oracle使用正则表达式离不开这4个函数:

1。regexp_like

2。regexp_substr

3。regexp_instr

4。regexp_replace

www.2cto.com

看函数名称大概就能猜到有什么用了。

regexp_like 只能用于条件表达式,和 like 类似,但是使用的正则表达式进行匹配,语法很简单:

regexp_substr 函数,和 substr 类似,用于拾取合符正则表达式描述的字符子串,语法如下:

regexp_instr 函数,和 instr 类似,用于标定符合正则表达式的字符子串的开始位置,语法如下:

regexp_replace 函数,和 replace 类似,用于替换符合正则表达式的字符串,语法如下:

这里解析一下几个参数的含义:

1。source_char,输入的字符串,可以是列名或者字符串常量、变量。

2。pattern,正则表达式。

3。match_parameter,匹配选项。

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

4。position,标识从第几个字符开始正则表达式匹配。

5。occurrence,标识第几个匹配组。

6。replace_string,替换的字符串。

Sql代码

oracle 10g正则表达式 REGEXP_LIKE 用法

/*

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

1,REGEXP_LIKE :与LIKE的功能相似

2,REGEXP_INSTR :与INSTR的功能相似

3,REGEXP_SUBSTR :与SUBSTR的功能相似

4,REGEXP_REPLACE :与REPLACE的功能相似

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

但是它们使用POSIX 正则表达式代替了老的百分号(%)和通配符(_)字符。

POSIX 正则表达式由标准的元字符(metacharacters)所构成:

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

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

配 ‘\n‘ 或 ‘\r‘。

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

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

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

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

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

字符串。

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

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

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

出现m次。

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

字符簇:

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

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

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

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

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

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

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

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

各种操作符的运算优先级

\转义符

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

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

^, $, anymetacharacter 位置和顺序

|

*/

www.2cto.com

Sql代码

[email protected]> create table fzq

2  (

3  id varchar(4),

4  value varchar(10)

5  );

表已创建。

[email protected]> --数据插入

[email protected]> insert into fzq values

2  (‘1‘,‘1234560‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘2‘,‘1234560‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘3‘,‘1b3b560‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘4‘,‘abc‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘5‘,‘abcde‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘6‘,‘ADREasx‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘7‘,‘123 45‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘8‘,‘adc de‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘9‘,‘adc,.de‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘10‘,‘1B‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘10‘,‘abcbvbnb‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘11‘,‘11114560‘);

已创建 1 行。

[email protected]> insert into fzq values

2  (‘11‘,‘11124560‘);

已创建 1 行。

[email protected]> commit;

提交完成。

[email protected]> select * from fzq where value like ‘1____60‘;

ID   VALUE

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

1    1234560

2    1234560

3    1b3b560

[email protected]> select * from fzq where regexp_like(value,‘1....60‘);

ID   VALUE

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

1    1234560

2    1234560

3    1b3b560

11   11114560

11   11124560

[email protected]> select * from fzq where regexp_like(value,‘1[0-9]{4}60‘);

ID   VALUE

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

1    1234560

2    1234560

11   11114560

11   11124560

[email protected]> select * from fzq where regexp_like(value,‘1[[:digit:]]{4}60‘);

ID   VALUE

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

1    1234560

2    1234560

11   11114560

11   11124560

[email protected]> select * from fzq where not regexp_like(value,‘^[[:digit:]]+$‘);

ID   VALUE

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

3    1b3b560

4    abc

5    abcde

6    ADREasx

7    123 45

8    adc de

9    adc,.de

10   1B

10   abcbvbnb

已选择9行。

[email protected]> -- 查询value中不是纯数字的记录

[email protected]> select * from fzq where not regexp_like(value,‘^[[:digit:]]+$‘);

ID   VALUE

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

3    1b3b560

4    abc

5    abcde

6    ADREasx

7    123 45

8    adc de

9    adc,.de

10   1B

10   abcbvbnb

已选择9行。

[email protected]> -- 查询value中不包含任何数字的记录。

[email protected]> select * from fzq where regexp_like(value,‘^[^[:digit:]]+$‘);

ID   VALUE

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

4    abc

5    abcde

6    ADREasx

8    adc de

9    adc,.de

10   abcbvbnb

已选择6行。

www.2cto.com

[email protected]> --查询以12或者1b开头的记录.不区分大小写。

[email protected]> select * from fzq where regexp_like(value,‘^1[2b]‘,‘i‘);

ID   VALUE

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

1    1234560

2    1234560

3    1b3b560

7    123 45

10   1B

[email protected]> --查询以12或者1b开头的记录.区分大小写。

[email protected]> select * from fzq where regexp_like(value,‘^1[2B]‘);

ID   VALUE

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

1    1234560

2    1234560

7    123 45

10   1B

[email protected]> -- 查询数据中包含空白的记录。

[email protected]> select * from fzq where regexp_like(value,‘[[:space:]]‘);

ID   VALUE

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

7    123 45

8    adc de

[email protected]> --查询所有包含小写字母或者数字的记录。

[email protected]> select * from fzq where regexp_like(value,‘^([a-z]+|[0-9]+)$‘);

ID   VALUE

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

1    1234560

2    1234560

4    abc

5    abcde

10   abcbvbnb

11   11114560

11   11124560

已选择7行。

[email protected]> --查询任何包含标点符号的记录。

[email protected]> select * from fzq where regexp_like(value,‘[[:punct:]]‘);

ID   VALUE

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

9    adc,.de

[email protected]>

[email protected]> select * from dual where regexp_like(‘b‘, ‘^[abc]$‘);

www.2cto.com

D

-

X

[email protected]>

[email protected]> select * from dual where regexp_like(‘abc‘, ‘^[abc]$‘);

未选定行

[email protected]>

[email protected]> select * from dual where regexp_like(‘abc‘, ‘^a[abc]c$‘);

D

-

X

[email protected]>

[email protected]> spool off;

时间: 2024-10-02 09:42:39

Oracle正则表达式函数:regexp_like、regexp_substr、regexp_instr、regexp_replace的相关文章

Oracle 正则表达式函数-REGEXP_LIKE 使用例子

原文在这 戳 REGEXP_LIKE 3个参数 第一个是输入的字符串 第二个是正则表达式 第三个是取值范围: i:大小写不敏感: c:大小写敏感: n:点号 . 不匹配换行符号: m:多行模式: x:扩展模式,忽略正则表达式中的空白字符. 全部测试数据 SQL> SELECT * FROM test_reg_like; A ---------------------------------------- ABC A12 12a12 匹配字母A的 SQL> SELECT 2 * 3 FROM 4

Oracle正则表达式之 Regexp_substr,Regexp_instr,Regexp_replace,Regexp_like

Oracle正则表达式使用介绍 正则表达式具有强大.便捷.高效的文本处理功能.能够添加.删除.分析.叠加.插入和修整各种类型的文本和数据.Oracle从10g开始支持正则表达式 下面通过一些例子来说明使用正则表达式来处理一些工作中常见的问题. 1. REGEXP_SUBSTR REGEXP_SUBSTR 函数使用正则表达式来指定返回串的起点和终点,返回与source_string 字符集中的VARCHAR2 或CLOB 数据相同的字符串. 语法: --1.REGEXP_SUBSTR与SUBSTR

oracle正则表达式函数和正则表达式简介

Oracle使用正则表达式4个函数:   1.regexp_like(expr_col,'正则表达式') 2.regexp_substr(expr_col,'   3.regexp_instr     4.regexp_replace POSIX 正则表达式由标准的元字符(metacharacters)所构成:   '^' 匹配输入字符串的开始位置,在方括号表达式中使用,此时它表示不接受该字符集合.   '$' 匹配输入字符串的结尾位置.如果设置了 RegExp 对象的 Multiline 属性

Oracle 正则表达式函数-REGEXP_SUBSTR 使用例子

原文在这 戳 REGEXP_SUBSTR 5个参数 第一个是输入的字符串 第二个是正则表达式 第三个是标识从第几个字符开始正则表达式匹配.(默认为1) 第四个是标识第几个匹配组.(默认为1) 第五个是是取值范围: i:大小写不敏感: c:大小写敏感: n:点号 . 不匹配换行符号: m:多行模式: x:扩展模式,忽略正则表达式中的空白字符. 全部测试数据 SQL> select * from test_reg_substr; A ---------------------------------

Oracle 正则表达式函数-REGEXP_INSTR 使用例子

原文在这 戳 REGEXP_INSTR 6个参数 第一个是输入的字符串 第二个是正则表达式 第三个是标识从第几个字符开始正则表达式匹配.(默认为1) 第四个是标识第几个匹配组.(默认为1) 第五个是指定返回值的类型,如果该参数为0,则返回值为匹配位置的第一个字符,如果该值为非0则返回匹配值的最后一个位置. 第六个是是取值范围: i:大小写不敏感: c:大小写敏感: n:点号 . 不匹配换行符号: m:多行模式: x:扩展模式,忽略正则表达式中的空白字符. 全部测试数据 SQL> select *

Oracle 正则表达式函数-REGEXP_REPLACE 使用例子

原文在这: 戳 6个参数 第一个是输入的字符串 第二个是正则表达式 第三个是替换的字符 第四个是标识从第几个字符开始正则表达式匹配.(默认为1) 第五个是标识第几个匹配组.(默认为全部都替换掉) 第六个是是取值范围: i:大小写不敏感: c:大小写敏感: n:点号 . 不匹配换行符号: m:多行模式: x:扩展模式,忽略正则表达式中的空白字符. 全部测试数据 SQL> select * from test_reg_substr; A -------------------------------

oracle 正则表达式 匹配

oracle 正则表达式 在实际应用中,想排除带有中文的字段值: select h.froomnumber from t_broker_house h where REGEXP_LIKE(froomnumber,'^([a-z0-9A-Z]|-)*$') 字符串’^198[0-9]$’可以匹配‘1980-1989’,如果希望统计出公司那些员工是80年-89年入职的,就可以使用如下的SQL语句: select * from emp e where regexp_like(to_char( e.hi

oracle正则表达式的用法

<SPAN style="FONT-SIZE: 18px">Oracle 正则表达式函数-REGEXP_SUBSTR 使用例子 .5个参数 第一个是输入的字符串 第二个是正则表达式 第三个是标识从第几个字符开始正则表达式匹配.(默认为1) 第四个是标识第几个匹配组.(默认为1) 第五个是是取值范围: i:大小写不敏感: c:大小写敏感: n:点号 . 不匹配换行符号: m:多行模式: x:扩展模式,忽略正则表达式中的空白字符. 全部测试数据SQL> select *

oracle正则表达式regexp_like的用法详解

ORACLE中的支持正则表达式的函数主要有下面四个:1,REGEXP_LIKE :与LIKE的功能相似2,REGEXP_INSTR :与INSTR的功能相似3,REGEXP_SUBSTR :与SUBSTR的功能相似4,REGEXP_REPLACE :与REPLACE的功能相似它们在用法上与Oracle SQL 函数LIKE.INSTR.SUBSTR 和REPLACE 用法相同,但是它们使用POSIX 正则表达式代替了老的百分号(%)和通配符(_)字符.POSIX 正则表达式由标准的元字符(met