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

结果:

相关推荐
山茶花开时。15 小时前
[Oracle] NVL()函数
数据库·oracle
Shun_Tianyou18 小时前
Python Day21 re模块正则表达式 简单小说爬取 及例题分析
开发语言·数据结构·python·算法·正则表达式
小白跃升坊1 天前
MaxKB 使用 MCP 连接 Oracle (免安装 cx_Oracle 和 Oracle Instant Client)
数据库·oracle·maxkb·mcp
码明1 天前
42.MySQL视图
数据库·oracle
山茶花开时。1 天前
[Oracle] TO_NUMBER()函数
数据库·oracle
春天的菠菜1 天前
【mysql】设置mysql数据库只读权限用户
数据库·oracle
2501_920047032 天前
Mysql-事务
数据库·mysql·oracle
ZZH1120KQ2 天前
ORACLE复杂查询
数据库·oracle
山茶花开时。2 天前
[Oracle] TO_DATE()函数
数据库·oracle
2501_927030782 天前
SQL基础语法
数据库·sql·oracle