目录
注:此函数为 MySQL8.0 版本新增,低于8.0版本没有此函数。
regexp_replace(expr, pat, repl[, pos[, occurrence[, match_type]]])
用法
将字符串expr与pat指定的正则表达式匹配的匹配项,替换为字符串repl,并返回结果字符串。如果expr、pat或repl为NULL,则返回值为NULL。
参数
- expr:要替换的原始字符串,或者数据库表指定的列。
- pat:要匹配的正则表达式,pat为空串时抛异常,Illegal argument to a regular expression。
- repl:将匹配的pat替换成的字符串。
- pos:expr开始搜索的位置。如果省略,则默认值为 1。
- occurrence:要替换哪个匹配项。如果省略,则默认值为 0(表示“替换所有匹配项”)。
- match_type:指定如何执行匹配的任何或所有以下字符。(i:不区分大小写的匹配 默认。c:区分大小写的匹配。m: 多行模式。n:. 字符匹配行终止符。默认值是 .匹配在行尾停止。u: 仅 Unix 的行尾。只有换行符会被 、 和 match 运算符识别为以行结尾.的^行 $。)
用法
示例:基本用法,替换全部数字变成#。
select regexp_replace('1abc2', '[0-9]', '#');
输出:
示例:pos用法,从字符串第二位开始搜索,替换全部数字变成#。
select regexp_replace('12abc', '[0-9]', '#', 2);
输出:
格式化手机号,将+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
将字符用空格分隔开,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
SELECT regexp_replace("abcd","(.*)(.)$","\\1",0) ;
结果:abc
SELECT regexp_replace("abcd","(.*)(.)$","\\2",0) ;
结果:d
SELECT regexp_replace("abcd","(.*)(.)$","\\1-\\2",0) ;
结果:abc-d
其他案例:
SELECT regexp_replace("abcd","(.)","\\2",1) 结果为"abcd",因为pattern中只定义了一个组,引用的第二个组不存在。 SELECT regexp_replace("abcd","(.*)(.)$","\\2",0) 结果为"d" SELECT regexp_replace("abcd","(.*)(.)$","\\1",0) 结果为"abc" SELECT regexp_replace("abcd","(.*)(.)$","\\1-\\2",0) 结果为"abc-d" SELECT regexp_replace("abcd","a","\\1",0),结果为” \1bcd”,因为在pattern中没有组的定义,所以\1直接输出为字符。