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个字符开始找第二次匹配)

总结

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

相关文章

  • SQL中Limit的基本与高级用法详解

    SQL中Limit的基本与高级用法详解

    在SQL中LIMIT是一个用于限制结果集返回的行数的子句,这篇文章主要给大家介绍了关于SQL中Limit的基本与高级用法,文中通过代码介绍的非常详细,对大家学习或者使用sql具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-04-04
  • Mysql误删除DELETE数据找回操作指南

    Mysql误删除DELETE数据找回操作指南

    如果我们在数据库中不小心执行了类似"delete from t1"这样的不带where条件的语句,那么整张表的数据就全被删除了,下面这篇文章主要给大家介绍了关于Mysql误删除DELETE数据找回操作的相关资料,需要的朋友可以参考下
    2023-05-05
  • MySQL中查询当天数据中离时间点最近的数据(两种方法)

    MySQL中查询当天数据中离时间点最近的数据(两种方法)

    在 MySQL 中,你可以使用 ORDER BY 和 LIMIT 语句来查询当天数据中离指定时间最近的数据,本文给大家介绍MySQL中查询当天数据中离时间点最近的数据,感兴趣的朋友一起看看吧
    2023-12-12
  • MySQL 使用 Performance Schema 定位和解决慢 SQL 问题

    MySQL 使用 Performance Schema 定位和解决慢 

    本文介绍了如何使用MySQL的PerformanceSchema来定位和解决慢SQL查询问题,通过启用PerformanceSchema并分析相关的系统表,可以收集到详细的性能数据,从而识别出影响性能的SQL语句,优化策略包括优化查询语句、调整数据库配置等
    2025-02-02
  • sphinxql如何得到结果数及show meta的详细说明

    sphinxql如何得到结果数及show meta的详细说明

    想用sphinxql只得到结果数。跟mysql里的count(*)一样
    2013-02-02
  • 简单了解标准SQL的update语句三种用法

    简单了解标准SQL的update语句三种用法

    这篇文章主要介绍了简单了解标准SQL的update语句三种用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,,需要的朋友可以参考下
    2019-06-06
  • mysql仿asp的数据库操作类

    mysql仿asp的数据库操作类

    本文通过实例代码给大家介绍了mysql仿asp的数据库操作类,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2008-04-04
  • mysql5.7.20第一次登录失败的快速解决方法

    mysql5.7.20第一次登录失败的快速解决方法

    这篇文章主要介绍了mysql5.7.20第一次登录失败的快速解决方法,需要的朋友可以参考下
    2018-09-09
  • 在idea中使用mysql数据库超详细教程

    在idea中使用mysql数据库超详细教程

    这篇文章主要介绍了如何在IntelliJ IDEA中连接MySQL数据库,并使用控制台执行SQL语句,还详细讲解了如何使用MyBatis Generator快速生成实体类、接口和SQL文件,以及如何解决Lombok依赖问题,需要的朋友可以参考下
    2025-02-02
  • mysql count(*)分组之后IFNULL无效问题

    mysql count(*)分组之后IFNULL无效问题

    文章总结:作者分享了在解决MySQL中根据发票ID和单位统计单位数量的问题时遇到的困难及解决方法,通过使用IFNULL()函数和CASEWHEN都无法解决问题,最终作者选择了嵌套循环的方法来实现需求,并总结了经验以供参考
    2024-11-11

最新评论