MySQL中【正则表达式】用法

MySQL正则表达式 通过 REGEXPRLIKE 操作符实现(两者等价),用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例:


一、基础语法

sql 复制代码
SELECT column_name 
FROM table_name 
WHERE column_name REGEXP 'pattern';
-- 或
WHERE column_name RLIKE 'pattern';

二、常用元字符

元字符 说明 示例
^ 匹配开头 '^a' → 以 "a" 开头
$ 匹配结尾 'z$' → 以 "z" 结尾
. 匹配任意单个字符 'a.c' → "abc", "axc"
[...] 字符集合 '[aeiou]' → 匹配任一元音
[^...] 排除字符集合 '[^0-9]' → 非数字字符
* 前一个字符0次或多次 'ab*c' → "ac", "abbc"
+ 前一个字符1次或多次 'ab+c' → "abc", "abbc" (排除"ac")
{n} 前一个字符n次 'a{3}' → "aaa"
` ` 或操作

三、实际示例

  1. 匹配以数字开头的字符串

    sql 复制代码
    SELECT name FROM products WHERE name REGEXP '^[0-9]';
  2. 匹配包含特定单词的文本

    sql 复制代码
    SELECT content FROM logs WHERE content REGEXP 'error|warning';
  3. 匹配邮箱格式

    sql 复制代码
    SELECT email FROM users WHERE email REGEXP '^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$';
  4. 匹配连续重复字符

    sql 复制代码
    SELECT word FROM dictionary WHERE word REGEXP '(.)\\1'; -- 如 "book"('oo')

四、与 LIKE 的区别

特性 REGEXP LIKE
功能 复杂模式匹配 简单通配符 (%, _)
大小写敏感 默认不敏感(除非二进制字符串) 依赖字段排序规则
性能 通常较慢(全表扫描) 可能使用索引

五、进阶函数(MySQL 8.0+)

  1. REGEXP_REPLACE()

    替换匹配的字符串:

    sql 复制代码
    SELECT REGEXP_REPLACE('hello 123', '[0-9]+', 'world'); -- 结果: 'hello world'
  2. REGEXP_SUBSTR()

    提取匹配的子串:

    sql 复制代码
    SELECT REGEXP_SUBSTR('abc def ghi', '[a-z]+'); -- 结果: 'abc'
  3. REGEXP_INSTR()

    返回匹配的起始位置:

    sql 复制代码
    SELECT REGEXP_INSTR('abc123', '[0-9]+'); -- 结果: 4

六、注意事项

  1. 转义特殊字符 :使用双反斜杠 \\(如 \\+, \\.)。

  2. 性能优化 :避免在大型表上使用 REGEXP,优先考虑全文索引或预处理。

  3. 大小写敏感 :如需区分大小写,使用 BINARY 关键字:

    sql 复制代码
    WHERE BINARY column_name REGEXP 'Pattern';

经典案例:提取文本中的金额

sql 复制代码
SELECT 
  REGEXP_SUBSTR(description, '[0-9]+\\.[0-9]{2}') AS amount 
FROM orders 
WHERE description REGEXP '[0-9]+\\.[0-9]{2}';

匹配如 "Price: 99.99 USD" 中的 99.99

相关推荐
数据知道20 分钟前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_124987075320 分钟前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha21 分钟前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_25 分钟前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance31 分钟前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋1 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.1 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库
天天爱吃肉82182 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车
大巨头2 小时前
sql2008 数据库分页语句
数据库
m0_715575342 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python