Oracle 正则表达式匹配(Oracle 11g)

1、连续2词汉字重复或3词汉字重复(不会忽略符号)

复制代码
([^ \u4e00-\u9fa5\S]{2,3})\1

例如:阿富、

复制代码
SELECT REGEXP_replace('阿富、阿富、 阿富汗、    ', '([^ \u4e00-\u9fa5\S]{2,3})\1', '重复') FROM dual

结果:

2、连续2词汉字重复或3词汉字重复(忽略符号,只匹配汉字)

(使用 ASCII 范围来排除非汉字字符。请注意,这个方法可能不如 Unicode 属性精确,但在 Oracle 11g 中可能是一个可行的替代方案)

复制代码
([^ '||UNISTR('\3400-\4DBF\20000-\2A6DF\2A700-\2B73F\2B740-\2B81F\2B820-\2CEAF\2CEB0-\2EBEF')||']{2,3})\1

例如:

复制代码
SELECT REGEXP_replace('阿富、阿富、汗、', '([^ '||UNISTR('\3400-\4DBF\20000-\2A6DF\2A700-\2B73F\2B740-\2B81F\2B820-\2CEAF\2CEB0-\2EBEF')||']{2,3})\1', '重复') FROM dual

结果:

相关推荐
yzlAurora10 小时前
MySQL问题:MVCC是什么?
数据库·oracle
人生苦短12812 小时前
oracle查看函数
数据库·oracle
铃木隼.1 天前
MySQL数据库(一)
数据库·mysql·oracle
看到千里之外的云1 天前
用service 和 SCAN实现sqlplus/jdbc连接Oracle 11g RAC时负载均衡
数据库·oracle·负载均衡
袖清暮雨1 天前
ClickHouse讲解
大数据·数据库·数据仓库·clickhouse·oracle
麻花20131 天前
获取oracle的HQL日志,采取参数日志,拼装SQL语句
java·oracle
瀚高PG实验室1 天前
V9数据库替换授权
数据库·oracle·瀚高数据库
瀚高PG实验室1 天前
Oracle迁移到瀚高之后,空值问题处理(APP)
数据库·oracle·瀚高数据库
瓦哥架构实战2 天前
走进黑盒:SQL 是如何在数据库中执行的?
数据库·sql·oracle