承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

MySQL正则表达式regexp_replace函数的用法实例

管理员 2023-06-27 08:39:39 互联网圈 9 ℃ 0 评论 3699字 收藏

注:此函数为 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⑼]’, ‘#’);

输出:

 示例:pos用法,从字符串第二位开始搜索,替换全部数字变成#。

select regexp_replace(’12abc’, ‘[0⑼]’, ‘#’, 2);

输出:

格式化手机号,将+86 13811112222转换为(+86) 138⑴111⑵222,’+‘在正则表达式中有定义,需要转义。\\1表示援用的第一个组

SELECT regexp_replace(‘+86 13811112222′,'(\\+[0⑼]{2})( )([0⑼]{3})([0⑼]{4})([0⑼]{4})’,'(\\1)\\3-\\4-\\5′,0);

结果:(+86)138⑴111⑵222

结果:(123)456⑺890

将字符用空格分隔开,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

结果:abc

结果:d

结果:abc-d

其他案例:

总结

到此这篇关于MySQL正则表达式regexp_replace函数用法的文章就介绍到这了,更多相关MySQL正则表达式regexp_replace函数内容请搜索之前的文章或继续浏览下面的相关文章希望大家以后多多支持!

文章来源:丸子建站

文章标题:MySQL正则表达式regexp_replace函数的用法实例

https://www.wanzijz.com/view/59874.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信