mysql正则函数REGEXP使用及说明

 更新时间:2026年05月18日 09:35:56   作者:yubin1285570923  
本文介绍了MySQL中的正则表达式匹配操作符REGEXP及其在不同版本中的使用方法和差异,包括基本语法、支持的元字符与量词、版本差异及常用函数如REGEXP_LIKE、REGEXP_SUBSTR、REGEXP_REPLACE等

在 MySQL 中,REGEXP 是用于‌正则表达式模式匹配‌的操作符,其功能与 RLIKE 相同。

从 MySQL 8.0 开始,还引入了更规范的函数形式如 REGEXP_LIKE()、REGEXP_SUBSTR()、REGEXP_REPLACE() 等,增强了正则处理能力。

核心要点‌

基本语法‌

column_name REGEXP ‘pattern’:返回 1(匹配)或 0(不匹配)。

默认‌不区分大小写‌,但受字段排序规则(collation)影响;若需区分大小写,可使用 BINARY 或 REGEXP_LIKE(…, ‘c’)。

支持的元字符与量词‌(基于 Henry Spencer 正则库,POSIX ERE 子集):

^、$、.、*、+、?、[]、|、{n}、{n,}、{n,m}

不支持‌ \d、\w、\s 等 Perl 风格简写,应分别用 [0-9]、[a-zA-Z0-9]、[[:space:]] 替代。

版本差异‌

‌MySQL 5.7 及以下‌:仅支持基本 POSIX BRE,部分语法(如 +、?)需转义或改用 {1,}、{0,1}。

‌MySQL 8.0+‌:采用 ICU 引擎,支持更多 POSIX ERE 特性,推荐使用 REGEXP_LIKE() 等函数以提高可读性和控制力。

常用函数与示例

‌REGEXP_LIKE()(MySQL 8.0+)

SELECT * FROM users WHERE REGEXP_LIKE(email, '^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$', 'c');

REGEXP_SUBSTR()(MySQL 8.0+)‌

提取首次匹配的子串

SELECT REGEXP_SUBSTR('user_123_order_456', '[0-9]+', 1, 1); -- 返回 '123'

REGEXP_REPLACE()(MySQL 8.0+)‌

替换匹配内容

SELECT REGEXP_REPLACE('abc123def', '[0-9]+', ''); -- 返回 'abcdef'

REGEXP_INSTR()(MySQL 8.0+)‌

返回匹配位置(从 1 开始)

SELECT REGEXP_INSTR('dog cat dog', 'dog'); -- 返回 1
SELECT REGEXP_INSTR('dog cat dog', 'dog', 2); -- 返回 9(从第2个字符开始找第二次匹配)

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 使用mysql语句对分组结果进行再次筛选方式

    使用mysql语句对分组结果进行再次筛选方式

    这篇文章主要介绍了使用mysql语句对分组结果进行再次筛选方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • mysql的虚拟表(DUAL)的介绍及使用场景

    mysql的虚拟表(DUAL)的介绍及使用场景

    本文主要介绍了mysql的虚拟表(DUAL)的介绍及使用场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-04-04
  • MySQL中触发器入门简单实例与介绍

    MySQL中触发器入门简单实例与介绍

    本文章来mysql初学者介绍在mysql怎么创建触发器及触发器在mysql执行顺序,下面我来给大家详细介绍
    2013-08-08
  • MySQL多表关联查询方式及实际应用

    MySQL多表关联查询方式及实际应用

    MySQL语句学习的难点和重点就在于多表查询,同时MySQL也有诸多方法供大家选择,不论是多表联查(联结表、左连接、右连接……),这篇文章主要给大家介绍了关于MySQL多表关联查询方式及实际应用的相关资料,需要的朋友可以参考下
    2024-07-07
  • redis服务器环境下mysql实现lnmp架构缓存

    redis服务器环境下mysql实现lnmp架构缓存

    这篇文章主要介绍了redis系统环境下mysql实现lnmp架构缓存,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • MySQL 数据库两台主机同步实战(linux)

    MySQL 数据库两台主机同步实战(linux)

    MySQL支持单向、异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,并维护日志文件的一个索引以跟踪日志循环。
    2009-04-04
  • MySQL优化之分区表

    MySQL优化之分区表

    这篇文章主要介绍了MySQL优化之分区表,需要的朋友可以参考下
    2016-06-06
  • Mysql中条件字段有索引,但使用不了索引的几种场景详解

    Mysql中条件字段有索引,但使用不了索引的几种场景详解

    这篇文章主要介绍了Mysql中条件字段有索引,但使用不了索引的几种场景,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-04-04
  • mysql创建用户授权步骤详解

    mysql创建用户授权步骤详解

    这篇文章主要介绍了mysql创建用户授权,本文分步骤给大家介绍的非常详细,对mysql创建用户授权详细步骤感兴趣的朋友一起看看吧
    2023-07-07
  • mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

    mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL ser

    本文主要介绍了mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法,具有一定的参考价值,感兴趣的可以了解一下
    2025-03-03

最新评论