网站首页 > 技术文章 正文
Oracle中使用正则表达式需先使用REGEXP_LIKE函数来匹配字符串。正则表达式的语法与一般正则表达式相似,但具体的写法也受不同版本的Oracle环境不同。
在Oracle 10g及以下版本中,可以使用POSIX扩展来进行正则匹配
如:
^:匹配字符串的开始位置;
$:匹配字符串的结束位置;
.:匹配任何单个字符;
[ ]:匹配指定集合内的任何字符,如[abc]匹配a、b、c中任意一个字符;
[^ ]:匹配不在指定集合内的任何字符,如[^abc]匹配除a、b、c之外的任意字符;
*:匹配前面的子表达式零次或多次;
+:匹配前面的子表达式一次或多次;
?:匹配前面的子表达式零次或一次;
{n}:n为非负整数,匹配恰好n次;
{n,}:n为非负整数,匹配至少n次;
{n,m}:n和m为非负整数且n<=m,匹配至少n次且至多m次。
例如,可以使用REGEXP_LIKE函数配合正则表达式来查找符合条件的字符串:
- SELECT *
- FROM employees
- WHERE REGEXP_LIKE(job_title, '^Sales.*Manager#39;);
上述SQL查询会查找职位名称以“Sales”开头,且以“Manager”结尾的所有员工数据。
Oracle 11g及以上版本
对于Oracle 11g及以上版本,可以使用更强大的perl兼容正则表达式(PCRE)来进行匹配
在使用PCRE时,先需要使用REGEXP_REPLACE函数中加入’c’选项进行匹配,然后再使用相应的正则表达式来实现匹配。
例如,可以使用如下的SQL查询来查找所有包含“John”或“Johnson”的名称:
- SELECT *
- FROM employees
- WHERE REGEXP_REPLACE(name, '(John|Johnson)', '*', 1, 0, 'c') != name;
我的实际例子:
- SELECT *
- --DISTINCT CODE,count(1)
- FROM table
- WHERE 1 = 1
- AND DATA_CATE = 'CPAU'
- --AND ext_5 LIKE 'ASSM%'
- AND REGEXP_REPLACE(ext_5, '(ASSM01|PSVA0100)', '*', 1, 0, 'c') != ext_5;
- AND VALID_FLG = 'Y'
是否走索引
正则表达式的匹配通常需要对目标字符串全文扫描,因此,在大多数情况下,使用正则表达式无法利用数据库索引。也就是说,在使用正则表达式时,往往无法使用索引来优化查询。
例如,假设有一个包含文本的表,其中有一个 text 字段,我们希望查找所有包含“abc”字符的记录。如果使用 LIKE 操作符,可以这样写:
SELECT * FROM table WHERE text LIKE ‘%abc%’;
如果 text 字段上有索引,那么这个查询会利用索引优化执行,因为 LIKE 操作符可以使用前缀索引。但是,如果使用正则表达式,查询语句将变为:
SELECT * FROM table WHERE REGEXP_LIKE(text, ‘abc’);
在这种情况下,不能使用索引来优化查询,因为 REGEXP_LIKE 函数需要全文扫描才能找到匹配的记录。
虽然正则表达式在某些情况下可能无法使用索引优化,但是可以尽可能地使用模糊查询来代替正则表达式,从而使用索引来优化查询。例如,在上面的例子中,可以使用 LIKE 操作符而不是 REGEXP_LIKE 函数来查询相同的数据。虽然 LIKE 操作符不能使用正则表达式语法,但是它可以使用前缀索引进行优化,可以在满足需求的情况下提高性能。
猜你喜欢
- 2024-11-03 《MySQL 入门教程》第15篇MySQL常用函数之字符函数
- 2024-11-03 关于Oracle和PostgreSQL中非正常日期提取并转换
- 2024-11-03 分享一个有意思的渗透测试工具——sqlmap
- 2024-11-03 黑客最喜欢的脚本之一Perl,让你拥有无限可能
- 2024-11-03 「NLP2005年以来大突破」语义角色标记深度模型,准确率提升10%
- 2024-11-03 自生成数据实现LLM自我纠正,DeepMind新突破:纠正性能提升15.9%
- 2024-11-03 超越99.9%人类玩家,微软专业十段麻将AI论文细节首次公布
- 2024-11-03 如何避免出现 SQL 注入漏洞 如何避免 sql 注入?
- 2024-11-03 Linux命令-nl命令 linux命令nano
- 2024-11-03 Grails指南22查询基础 grails中文参考手册
你 发表评论:
欢迎- 623℃几个Oracle空值处理函数 oracle处理null值的函数
- 615℃Oracle分析函数之Lag和Lead()使用
- 603℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 599℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 595℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 588℃【数据统计分析】详解Oracle分组函数之CUBE
- 576℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 565℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)