REGEXP_REPLACE的使用方法

37 篇文章 0 订阅

regexp_replace的使用非常灵活,且容易忘记,故做此笔记。

没有过多的介绍使用说明,只是根据个人理解列出很多相似案例,个人觉得通过对比,更容易理解几个参数的使用技巧。

所有案例均是实跑出来的结果。

带颜色的部分是需要留意的地方。

命令格式:
regexp_replace(source, pattern, replace_string, occurrence)

参数说明:
● source: string类型,要替换的原始字符串。
● pattern: string类型常量,要匹配的正则模式,pattern为空串时抛异常。
● replace_string:string,将匹配的pattern替换成的字符串。
● occurrence: bigint类型常量,必须大于等于0,
大于0:表示将第几次匹配替换成replace_string,
等于0:表示替换掉所有的匹配子串。
其它类型或小于0抛异常。

返回值:
将source字符串中匹配pattern的子串替换成指定字符串后返回,当输入source, pattern, occurrence参数为NULL时返回NULL,若replace_string为NULL且pattern有匹配,返回NULL,replace_string为NULL但pattern不匹配,则返回原串。

常用案例

1、用’#‘替换字符串中的所有数字
SELECT regexp_replace(‘01234abcde56789’,’[0-9]’,’#’) AS new_str FROM dual;

结果:#####abcde#####

用’#‘替换字符串中的数字0、9
SELECT regexp_replace(‘01234abcde56789’,’[09]’,’#’) AS new_str FROM dual;

结果:#1234abcde5678#

2、遇到小写字母或者数字跳过,从匹配到的第4个值开始替换,替换为’’
SELECT regexp_replace(‘abcdefg123456ABC’,’[a-z0-9]’,’’,4)

结果:abcefg123456ABC

SELECT regexp_replace(‘abcDEfg123456ABC’,’[a-z0-9]’,’’,4)

结果:abcDEg123456ABC

SELECT regexp_replace(‘abcDEfg123456ABC’,’[a-z0-9]’,’’,7);

结果:abcDEfg13456ABC

遇到非小写字母或者数字跳过,将所有匹配到的值替换为’’
SELECT regexp_replace(‘abcDefg123456ABC’,’[a-z0-9]’,’’,0);

结果:DABC

3、格式化手机号,将+86 13811112222转换为(+86) 138-1111-2222,’+‘在正则表达式中有定义,需要转义。\1表示引用的第一个组
SELECT regexp_replace(’+86 13811112222’,’(\+[0-9]{2})( )([0-9]{3})([0-9]{4})([0-9]{4})’,’(\1)\3-\4-\5’,0);

结果:(+86)138-1111-2222

SELECT regexp_replace(“123.456.7890”,"([[:digit:]]{3})\.([[:digit:]]{3})\.([[:digit:]]{4})","(\1)\2-\3",0) ;
SELECT regexp_replace(“123.456.7890”,"([0-9]{3})\.([0-9]{3})\.([0-9]{4})","(\1)\2-\3",0) ;

结果:(123)456-7890

4、将字符用空格分隔开,0表示替换掉所有的匹配子串。
SELECT regexp_replace(‘abcdefg123456ABC’,’(.)’,’\1 ',0) AS new_str FROM dual;

结果:a b c d e f g 1 2 3 4 5 6 A B C

SELECT regexp_replace(‘abcdefg123456ABC’,’(.)’,’\1 ',2) AS new_str FROM dual;

结果:ab cdefg123456ABC

5、
SELECT regexp_replace(“abcd”,"(.*)(.)$","\1",0) ;
结果:abc

SELECT regexp_replace(“abcd”,"(.*)(.)$","\2",0) ;
结果:d

SELECT regexp_replace(“abcd”,"(.*)(.)KaTeX parse error: Undefined control sequence: \* at position 159: …lace("abcd","(.\̲*̲)(.)","\2",0) 结果为"d"
SELECT regexp_replace(“abcd”,"(.*)(.)KaTeX parse error: Undefined control sequence: \* at position 56: …lace("abcd","(.\̲*̲)(.)","\1-\2",0) 结果为"abc-d"
SELECT regexp_replace(“abcd”,“a”,"\1",0),结果为” bcd”,因为在pattern中没有组的定义,所以直接输出为字符。

正则符号释义:

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值