Oracle中正则表达式怎么用
发表于:2024-10-25 作者:千家信息网编辑
千家信息网最后更新 2024年10月25日,小编给大家分享一下Oracle中正则表达式怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Oracle使用正则表达式离
千家信息网最后更新 2024年10月25日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安全错误
数据库的锁怎样保障安全
山西服务器机箱供应云主机
关于身边的网络安全故事
鼎信诺前段数据库转换错误
软件开发在青岛好找工作吗
数据库中的多张表中如何关联
交换机外网服务器端口
阿里云数据库怎么进入
软件开发工资属于研发费用吗
网络技术专插本考什么
靠谱的软件开发维护
网络技术需要什么证
网络安全攻防保卫战
工信部加强网络安全风险
数据库表里的日期长度
找不到服务器应用程序怎么办
哲盟软件开发知乎
沈阳软件开发外包
黄易群侠传服务器自动维护时间
海外网络安全最新资讯
论文上传知网数据库需要多久
手机网络安全测试报告
考研转网络安全
软件开发在青岛好找工作吗
oracle数据库锁死
datago数据库代查
兰职技能大赛网络安全
居民对网络安全有什么需求
农村网络安全标语
下载服务器连接失败
三级网络技术靠的是啥