MySQL 正则表达式:regexp_substr 函数用法

MySQL regexp_replace() 函数用于模式匹配。它通过匹配字符来替换给定的字符串。


注:此函数为 MySQL8.0 版本新增,低于8.0版本没有此函数。

regexp_replace(expr, pat, repl[, pos[, occurrence[, match_type]]])

参数
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 运算符识别为以行结尾.的^行 $。)


MySQL正则表达式regexp_replace函数三种基本用法



示例1:基本用法,替换全部数字变成#。

select regexp_replace('1abc2', '[0-9]', '#');
输出:#abc#


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

select regexp_replace('1abc234', '[0-9]', '#', 2);

输出:1abc###


示例3:正则替换,返回匹配项

select REGEXP_REPLACE('text', ']*>(.*?)<\/a>', '$1');

输出:text