MySQL数据库中正则表达式(Regex)和like的区别详析
核心区别:通配符 vs 模式语言
LIKE:使用简单的通配符%:匹配任意多个字符(包括0个)_:匹配单个字符
正则表达式:使用完整的模式描述语言
具体对比
1.匹配能力对比
| 需求场景 | LIKE 实现 | 正则表达式实现 | 说明 |
|---|---|---|---|
| 以"A"开头 | LIKE 'A%' | ^A | 两者都能做到 |
| 包含"abc" | LIKE '%abc%' | abc | 两者都能做到 |
| 精确5个字符 | LIKE '_____' | ^.{5}$ | LIKE需要5个_,不直观 |
| 数字开头 | ❌ 无法实现 | ^\d | LIKE无法匹配"任意数字" |
| 邮箱验证 | ❌ 极其困难 | ^\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中大小写敏感问题导致的MySql Error 1146 Tabel doen’t exist错误
这篇文章主要介绍了Mysql中大小写敏感问题导致的MySql Error 1146 Tabel doen’t exist错误,需要的朋友可以参考下2014-10-10
MySql InnoDB存储引擎之Buffer Pool运行原理讲解
缓冲池是用于存储InnoDB表,索引和其他辅助缓冲区的缓存数据的内存区域。缓冲池的大小对于系统性能很重要。更大的缓冲池可以减少磁盘I/O来多次访问同一表数据。在专用数据库服务器上,可以将缓冲池大小设置为计算机物理内存大小的百分之802023-01-01
MySQL删除外键时报错Error Code:1091. Can‘t DROP ‘XXX‘的解决方法
这篇文章主要给大家介绍了关于MySQL删除外键时报错Error Code:1091. Can‘t DROP ‘XXX‘的解决方法,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2022-08-08


最新评论