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

原文在这

REGEXP_SUBSTR

5个参数

第一个是输入的字符串

第二个是正则表达式

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

第四个是标识第几个匹配组。(默认为1)

第五个是是取值范围:

i:大小写不敏感;

c:大小写敏感;

n:点号 . 不匹配换行符号;

m:多行模式;

x:扩展模式,忽略正则表达式中的空白字符。

全部测试数据

SQL> select * from test_reg_substr;

A

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

ABC123XYZ

ABC123XYZ456

<Name>Edward</Name>

检索中间的数字

SQL> SELECT

2    REGEXP_SUBSTR(a,‘[0-9]+‘)

3  FROM

4    test_reg_substr

5  WHERE

6    REGEXP_LIKE(a, ‘[0-9]+‘);

REGEXP_SUBSTR(A,‘[0-9]+‘)

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

123

123

检索中间的数字(从第一个字母开始匹配,找第2个匹配项目)

SQL> SELECT

2    NVL(REGEXP_SUBSTR(a,‘[0-9]+‘,1, 2), ‘-‘) AS a

3  FROM

4    test_reg_substr

5  WHERE

6    REGEXP_LIKE(a, ‘[0-9]+‘);

A

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

-

456

取得“字符集合”

SQL> SELECT

2    REGEXP_SUBSTR(a, ‘\w+‘)

3  FROM

4    test_reg_substr

5  WHERE

6    REGEXP_LIKE(a, ‘\w+‘);

REGEXP_SUBSTR(A,‘\W+‘)

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

ABC123XYZ

ABC123XYZ456

Name

取得“字符集合”(从第一个字母开始匹配,找第2个匹配项目)

SQL> SELECT

2    NVL(REGEXP_SUBSTR(a, ‘\w+‘,1, 2), ‘-‘) AS a

3  FROM

4    test_reg_substr

5  WHERE

6    REGEXP_LIKE(a, ‘\w+‘);

A

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

-

-

Edward

时间: 2024-08-09 02:05:10

Oracle 正则表达式函数-REGEXP_SUBSTR 使用例子的相关文章

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_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正则表达式函数: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_repla

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 over 函数几个例子

测试使用的数据为scott/tiger模式下的emp表: 我们使用JOB和SAL这两个列测试: 上面语句指按照职业JOB分组(partition by job)然后在每个分组内,按照薪水(sal)进行排名.注意到并列名次,例如SLAESMAN这个职业的,有两个1250并列第一,1500就是第3名了. 将RANK()换成DENSE_RAND看看区别: 可以看到,在处理并列问题上,并列的名次不占用名次编号. 另外还有一个常用的分析函数是SUM() OVER: SUM() OVER计算累计求和,从第一

oracle正则表达式的用法

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

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