MySQL数据库中正则表达式(Regex)和like的区别详析

 更新时间:2025年11月29日 11:21:09   作者:又是长脑子的一天  
MySQL正则表达式是一种强大的文本匹配工具,允许执行复杂的字符串搜索和处理,这篇文章主要介绍了MySQL数据库中正则表达式(Regex)和like区别的相关资料,文中通过代码需要的朋友可以参考下

核心区别:通配符 vs 模式语言

  • LIKE:使用简单的通配符

    • %:匹配任意多个字符(包括0个)

    • _:匹配单个字符

  • 正则表达式:使用完整的模式描述语言

具体对比

1.匹配能力对比

需求场景LIKE 实现正则表达式实现说明
以"A"开头LIKE 'A%'^A两者都能做到
包含"abc"LIKE '%abc%'abc两者都能做到
精确5个字符LIKE '_____'^.{5}$LIKE需要5个_,不直观
数字开头❌ 无法实现^\dLIKE无法匹配"任意数字"
邮箱验证❌ 极其困难^\w+@\w+\.\w+$LIKE难以精确匹配
密码强度❌ 无法实现^(?=.*[A-Z])(?=.*\d).{8,}$LIKE无法做前瞻断言

2.实际案例演示

假设我们有一个用户表,要查找符合以下条件的用户名:

需求:找到以数字开头,第三个字符是元音字母,总长度至少为5的用户名

sql

-- 使用 LIKE  几乎不可能实现
-- 我们需要枚举所有可能性:
SELECT * FROM users WHERE 
  name LIKE '0_a%' OR 
  name LIKE '1_a%' OR 
  name LIKE '2_a%' OR 
  -- ... 需要写30种组合,极其繁琐!
  name LIKE '9_u%';

-- 使用正则表达式  一行搞定
SELECT * FROM users WHERE name REGEXP '^[0-9].[aeiou].{2,}';
-- 解释:^[0-9] 数字开头, . 任意字符, [aeiou] 元音字母, .{2,} 至少2个任意字符

3.性能考虑

  • LIKE:在固定开头的情况下(如 'A%')可以利用索引,性能较好

  • 正则表达式:通常无法利用索引,全表扫描,性能较差

sql

-- 能利用索引(如果name有索引)
SELECT * FROM users WHERE name LIKE 'John%';

-- 不能利用索引
SELECT * FROM users WHERE name LIKE '%John%';
SELECT * FROM users WHERE name REGEXP 'John';

4.适用场景总结

场景推荐使用原因
简单前缀/后缀匹配LIKE语法简单,可能利用索引
固定格式匹配LIKE如 LIKE 'ABC____'
复杂模式匹配正则表达式如邮箱、电话、特定模式
数据验证正则表达式如密码强度、格式检查
数据提取正则表达式如从文本中提取特定模式

结论

您的观察是对的——对于简单的模式匹配,LIKE 确实可以做到,而且应该优先使用,因为它的性能可能更好。

但是当需求变得复杂时:

  • LIKE 就像是一把螺丝刀——适合简单的拧螺丝工作

  • 正则表达式就像是一个多功能工具箱——能处理各种复杂的维修任务

经验法则

  • 能用 LIKE 解决的简单问题,就用 LIKE

  • 当 LIKE 需要写很长的 OR 条件或者根本无法实现时,就使用正则表达式

在实际的数据库工作中,两者都是重要的工具,根据具体需求选择合适的使用才是关键!

到此这篇关于MySQL数据库中正则表达式(Regex)和like区别的文章就介绍到这了,更多相关MySQL正则表达式Regex和like区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL ALTER语法的运用方法

    MySQL ALTER语法的运用方法

    我们今天主要向大家介绍的是MySQL ALTER语法的实际运用,如果你对这一技术,心存好奇的话,以下的文章将会揭开它的神秘面纱。
    2010-11-11
  • Mysql中大小写敏感问题导致的MySql Error 1146 Tabel doen’t exist错误

    Mysql中大小写敏感问题导致的MySql Error 1146 Tabel doen’t exist错误

    这篇文章主要介绍了Mysql中大小写敏感问题导致的MySql Error 1146 Tabel doen’t exist错误,需要的朋友可以参考下
    2014-10-10
  • 安全快速修改Mysql数据库名的5种方法

    安全快速修改Mysql数据库名的5种方法

    mysql中如何重命名数据库?这篇文章主要介绍了安全快速修改Mysql数据库名的5种方法,需要的朋友可以参考下
    2014-04-04
  • MySql InnoDB存储引擎之Buffer Pool运行原理讲解

    MySql InnoDB存储引擎之Buffer Pool运行原理讲解

    缓冲池是用于存储InnoDB表,索引和其他辅助缓冲区的缓存数据的内存区域。缓冲池的大小对于系统性能很重要。更大的缓冲池可以减少磁盘I/O来多次访问同一表数据。在专用数据库服务器上,可以将缓冲池大小设置为计算机物理内存大小的百分之80
    2023-01-01
  • MySQL删除外键时报错Error Code:1091. Can‘t DROP ‘XXX‘的解决方法

    MySQL删除外键时报错Error Code:1091. Can‘t DROP ‘XXX‘的解决方法

    这篇文章主要给大家介绍了关于MySQL删除外键时报错Error Code:1091. Can‘t DROP ‘XXX‘的解决方法,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-08-08
  • MySQL数据库事务与锁深入分析

    MySQL数据库事务与锁深入分析

    这篇文章主要介绍了MySQL数据库事务与锁深入分析,内容介绍的非常详细,有对这方面不懂的同学可以跟着小编一起研究下吧
    2020-12-12
  • MySQL二进制日志binlog损坏的解决方案

    MySQL二进制日志binlog损坏的解决方案

    本文介绍了MySQL二进制日志(binlog)损坏的常见错误、原因和解决方案,包括尝试修复、使用分析工具、从备份恢复、检查磁盘及加强监控备份,并建议优先用备份恢复以保障数据安全,需要的朋友可以参考下
    2025-10-10
  • MySQL数据库如何开启远程连接(多备份)

    MySQL数据库如何开启远程连接(多备份)

    多备份服务器在备份你的数据库时,必须能够远程连接上你的数据库。但是一般来说mysql安装时都是关闭远程连接的,因此,需要你开通mysql数据库的远程访问权限。那么如何开启呢
    2015-01-01
  • MYSQL与sqlyog连接的实现

    MYSQL与sqlyog连接的实现

    本文主要介绍了MYSQL与sqlyog连接的实现,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-10-10
  • 超详细的SQL语句语法汇总

    超详细的SQL语句语法汇总

    个人整理的一些比较常用的SQL语句语法。需要的朋友可以过来参考下
    2013-08-08

最新评论