REGEXP正则表达式是定义搜索模式的字符序列。它用于检查表达式是否包含指定的搜索模式。

除了LIKE和NOT LIKE运算符之外,MySQL还支持另一种基于REGEXP函数和运算符的模式匹配操作。

MySQL REGEXP函数和运算符

以下是MySQL支持的 REGEXP 函数和运算符列表:

名称描述
NOT REGEXPREGEXP 的否定
NOT RLIKE否定 RLIKE
REGEXP用于检查字符串是否匹配正则表达式
REGEXP_INSTR() 匹配正则表达式的子字符串的起始索引
REGEXP_LIKE() 字符串是否匹配正则表达式
REGEXP_REPLACE()替换匹配正则表达式的子串
REGEXP_SUBSTR()返回匹配正则表达式的子串
RLIKE用于检查字符串是否匹配正则表达式

正则表达式模式

以下是表格模式语法,可与 REGEXP 函数和运算符一起使用。

正则表达式模式

符号描述
^匹配字符串的开头。
$匹配字符串的结尾字符串。
*匹配零次或多次出现。
+匹配一次或多次出现。
?匹配零次或一次出现。
.匹配除 NULL 之外的任何字符。
|像"OR"一样使用来指定多个替代字符。
[ ]匹配 [] 内指定的任何单个字符。
[^ ]匹配 [] 内未指定的任何单个字符。
-表示字符范围。
( )用于将表达式分组为子表达式。
{m}匹配 m
{m,}匹配至少 m 次。
{m,n}匹配至少 m 次,但不超过 n 次。
\nn 是 1 到 9 之间的数字。匹配找到的第 n 个子表达式在 ( ) 内遇到 \n 之前。
\d匹配数字字符。
\D匹配非数字字符。
\w匹配单词字符。
\W匹配非单词字符。
\s匹配空白字符。
\s匹配空白字符。
\S匹配非空白字符。
*?匹配前面的模式出现零次或多次。
+?匹配前面的模式出现一次或多次。
??匹配前面的模式零次或一次出现。
?匹配前面的模式n 次。
?与前面的模式匹配至少 n 次。
?匹配前面的模式至少 n 次,但不超过 m 次。
[..]匹配一种排序规则可以是多个字符的元素。
[=character_class=]表示一个等价类。它匹配具有相同排序值的所有字符,包括其自身。
[:character_class:]表示匹配属于该字符的所有字符的字符类

标准类列表名称

字符类名称含义
alnum字母数字字符
alpha字母字符
blank空白字符
cntrl控制字符
digit数字字符
graph图形字符
lower小写字母字符
print图形或空格字符
punct标点符号
space空格、制表符、换行符和回车符
upper大写字母字符
xdigit十六进制数字字符