发表于 3 天前

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

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

([^ \u4e00-\u9fa5\S]{2,3})\1 比方:阿富、
SELECT REGEXP_replace('阿富、阿富、 阿富汗、    ', '([^ \u4e00-\u9fa5\S]{2,3})\1', '重复') FROM dual
结果:
https://i-blog.csdnimg.cn/blog_migrate/26e1435f33806b618e63480a273375ef.png
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
结果:
https://i-blog.csdnimg.cn/blog_migrate/aa09b01a9c434619f12737c31b7135a2.png


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: Oracle 正则表达式匹配(Oracle 11g)