Oracle中正则表达式怎么用
发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,小编给大家分享一下Oracle中正则表达式怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Oracle使用正则表达式离
千家信息网最后更新 2025年01月21日Oracle中正则表达式怎么用
小编给大家分享一下Oracle中正则表达式怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
Oracle使用正则表达式离不开这4个函数:regexp_like、regexp_substr、regexp_instr、regexp_replace。
regexp_like
该函数只能用于条件表达式,和 like 类似,但是使用的正则表达式进行匹配
//查询所有包含小写字母或者数字的记录。 select * from fzq where regexp_like(value,'^([a-z]+|[0-9]+)$');
regexp_substr
该函数和 substr 类似,用于拾取合符正则表达式描述的字符子串,该函数的定义如下
function REGEXP_SUBSTR(String, pattern, position, occurrence, modifier) - String 输入的字符串 - pattern 正则表达式 - position 标识从第几个字符开始正则表达式匹配。(默认为1) - occurrence 标识第几个匹配组。(默认为1) - modifier 取值范围: i:大小写不敏感; c:大小写敏感; n:点号 . 不匹配换行符号; m:多行模式; x:扩展模式,忽略正则表达式中的空白字符。
下面是一些实例
--检索中间的数字SELECT REGEXP_SUBSTR(a,'[0-9]+') FROM test_reg_substr WHERE REGEXP_LIKE(a, '[0-9]+');--检索中间的数字(从第一个字母开始匹配,找第2个匹配项目)SELECT NVL(REGEXP_SUBSTR(a,'[0-9]+',1, 2), '-') AS a FROM test_reg_substr WHERE REGEXP_LIKE(a, '[0-9]+');
regexp_instr
该函数和 instr 类似,用于标定符合正则表达式的字符子串的开始位置,Oracle数据库中的REGEXP_INSTR函数的语法是
REGEXP_INSTR (source_char, pattern [, position [, occurrence [, return_option [, match_parameter ] ] ] ] ) - source_char 搜索值的字符表达式 - pattern 正则表达式 - position 可选。搜索在字符串中的开始位置。如果省略,则默认为1,这是字符串中的第一个位置。 - occurrence 可选。它是模式字符串中的第n个匹配位置。如果省略,默认为1。 - return_option 可选 指定Oracle返回的位置, 0那么Oracle将返回出现的第一个字符的位置。这是默认的, 1则Oracle返回字符之后发生的位置。 - match_parameter 取值范围: i:大小写不敏感; c:大小写敏感; n:点号 . 不匹配换行符号; m:多行模式; x:扩展模式,忽略正则表达式中的空白字符。
下面是一些实例
--找到字符串中的第一个"e"字的位置--返回2SELECT REGEXP_INSTR ('hello itmyhome', 'e') FROM dual; --"1"为开始位置 "2"是搜索第二个匹配的,"0"是return_option --返回出现的第一个字符位置"c"是区分大小写 ,所以将返回13SELECT REGEXP_INSTR ('my is itMyhome', 'm', 1, 2, 0, 'c') FROM dual;--SELECT REGEXP_INSTR ('World filled with love', 'with', 1, 1, 0, 'i') FROM dual;--匹配多个备选SELECT REGEXP_INSTR ('Itmyhome', 'a|i|o|e|u') FROM dual;
regexp_replace
该函数和 replace 类似,用于替换符合正则表达式的字符串,Oracle数据库中的REGEXP_REPLACE函数的语法是
REGEXP_REPLACE(source_char, pattern [, replace_string [, position [, occurrence [, match_parameter ] ] ] ]) - source_char 搜索值的字符表达式 - pattern 正则表达式 - replace_string 可选。匹配的模式将被替换replace_string字符串。 如果省略replace_string参数,将删除所有匹配的模式,并返回结果字符串。 - position 可选。在字符串中的开始位置搜索。如果省略,则默认为1。 - occurrence 它是模式字符串中的第n个匹配位置。如果省略,默认为1。 - match_parameter i:大小写不敏感; c:大小写敏感; n:点号 . 不匹配换行符号; m:多行模式; x:扩展模式,忽略正则表达式中的空白字符。
如下是一些实例
--字符串替换--luck is my network idSELECT REGEXP_REPLACE ('itmyhome is my network id', '^(\S*)', 'luck') FROM dual;--此示例将所指定的\d数字将以#字符替换--Result: '#, #, and ## are numbers in this example'SELECT REGEXP_REPLACE ('2, 5, and 10 are numbers in this example', '\d', '#') FROM dual;
以上是"Oracle中正则表达式怎么用"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
字符
表达式
正则
位置
字符串
模式
函数
大小
搜索
数字
实例
换行符
空白
篇文章
多行
内容
字母
数据
数据库
标识
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
新疆网络安全协议
保证网络安全和数据安全
软件开发行业市场竞争分析
hls直播服务器
数据库IVM
王牌战争怎么让自己的服务器有人
软件开发创造价值吗
庐江品质网络技术服务哪家好
警电合作网络安全表态发言
徐州app软件开发多少钱
威海代驾软件开发公司
计算机网络技术以后干什么
煤炭行业网络安全案例
肇庆市网络安全活动周
未来网络技术应用方向
清远移动网络安全工程师月薪
什么服务器需要配合数据库
安卓清空微信缓存数据库
邹平oa软件开发公司
文石网络技术有限公司
易管网数据库打不开
大学生面临网络安全问题及对策
服务器桌面进程被关掉怎么开
计算机网络技术以后干什么
全网公敌警局档案服务器
微信第三方服务器搭建
智多星软件开发
石景山区咨询软件开发概况
金山网络技术招聘
sql数据库虚拟内存设置