Oracle 正则表达式

一、Oracle 正则表达式相关函数

(1) regexp_like :同 like 功能相似(模糊 '匹配')

(2) regexp_instr :同 instr 功能相似(返回字符所在 '下标')

(3) regexp_substr : 同 substr 功能相似('截取' 字符串)

(4) regexp_replace:同 replace 功能相似( '替换' 字符串)

使用了 '正则表达式' 替代了老的 '百分比 %' 和 '通配符 _'

sql 复制代码
WITH AA AS (
    SELECT 'ABCDEF' AS NAME FROM DUAL
    UNION ALL
    SELECT 'ABCDEFG' AS NAME FROM DUAL
)
SELECT * FROM AA WHERE NAME LIKE 'A____F'; -- 其中'_'表示单个字符,Result:ABCDEF

二、正则规则

三、正则函数

regexp_substr():

参数解释:

bash 复制代码
srcstr    	 : 源字符串 -- source string
pattern   	 : 正则表达式
position  	 : 起始位置,默认 1
occurrence	 : 第几次出现,默认 1(匹配成功的次数,依次递增)
modifier  	 : 模式('i': 不区分大小写,'c': 区分大小写。 默认 'c')
subexpression: 含有子表达式 0-9, 默认 0:不含子表达式,1:第一个子表达式,以此类推

样例:

sql 复制代码
with temp_email as (
  select 1 user_no, '[email protected]' email from dual union all
  select 2 user_no, '[email protected]' email from dual union all
  select 3 user_no, '[email protected]' email from dual
)
select t.user_no 用户编号,
       regexp_substr(t.email,'[[:alnum:]]+') 用户名,
       regexp_substr(t.email, '\@[[:alnum:]]+\.[[:alnum:]]+') 邮箱后缀
       -- 两者等同
       --regexp_substr(t.email,'[a-zA-Z0-9]+') 用户名2,
       --regexp_substr(t.email, '\@[a-zA-Z0-9]+\.[a-zA-Z0-9]+') 邮箱后缀2
  from temp_email t;

结果:

sql 复制代码
SELECT REGEXP_SUBSTR('34,56,-23', '[^,]+', 1, LEVEL, 'i') AS STR FROM DUAL 
CONNECT BY LEVEL <= LENGTH('34,56,-23') - LENGTH(REGEXP_REPLACE('34,56,-23', ',', '')) + 1;

regexp_instr():

参数解释:

bash 复制代码
srcstr    	 : 源字符串 -- source string
pattern   	 : 正则表达式
position  	 : 起始位置,默认 1
occurrence	 : 第几次出现,默认 1(匹配成功的次数,依次递增)
returnparam  : 返回参数对应的下标(0:第一个位置的下标,非0:最后一个位置的下标)
modifier  	 : 模式('i': 不区分大小写,'c': 区分大小写。 默认 'c')
subexpression: 含有子表达式 0-9, 默认 0:不含子表达式,1:第一个子表达式,以此类推

样例:

sql 复制代码
select regexp_instr('1,23,456,7890', '[0-9]+', 1, 3) 匹配到的第一个字符下标, -- 6
       regexp_instr('1,23,456,7890', '[0-9]+', 1, 3, 1) 最后一个字符后一位的下标, -- 9
       regexp_instr('1234567890', '(123)(4)(56)(78)', 1, 1, 0, 'i', 4) 匹配到的第四个子表达式 -- 7
  from dual;

regexp_replace():

sql 复制代码
with temp_strings as (   
  select 'abc123' str from dual union all
  select '123abc' str from dual union all
  select 'a1b2c3' str from dual
)   
select t.str 源字符串,
       regexp_replace(t.str, '[0-9]', '', 1) 无数字字符串
  from temp_strings t;

regexp_like():

sql 复制代码
with temp_strings as (   
  select 'abc123' str from dual union all
  select '12abcd' str from dual union all
  select 'a1b2c3' str from dual
)   
select t.str 连续的三个数字字符
  from temp_strings t
 where regexp_like(t.str, '[0-9]{3}');
相关推荐
A charmer7 分钟前
【MySQL】数据库基础
数据库·mysql
pjx98723 分钟前
应用的“体检”与“换装”:精通Spring Boot配置管理与Actuator监控
数据库·spring boot·oracle
松树戈43 分钟前
PostgreSQL 分区表——范围分区SQL实践
数据库·sql·postgresql
bing_1581 小时前
Redis 的单线程模型对微服务意味着什么?需要注意哪些潜在瓶颈?
数据库·redis·微服务
wangzhongyudie1 小时前
SQL实战:01之行转列实现
数据库·sql
斗鹰一余洛晟1 小时前
工作中sql总结
数据库·sql
阿七想学习1 小时前
MySQL《事务》
数据库·mysql
Yang_yangyang1 小时前
mysql定时备份、打包、传输
数据库·mysql·自动化
大大大水蜜桃1 小时前
DNS主从同步及解析
数据库
DKPT1 小时前
正则表达式
java·数据库·笔记·学习·正则表达式