【MySQL】MySQL 中 REGEXP 的用法

MySQL 中 REGEXP 的用法

在 MySQL 中,REGEXP 是一种用于进行正则表达式匹配的运算符。它允许你在查询中使用正则表达式来匹配字符串模式。

1. 基本语法

基本的语法结构如下:

sql 复制代码
SELECT * FROM table_name WHERE column_name REGEXP 'pattern';

2. 示例

匹配包含特定字符的行:

sql 复制代码
SELECT * FROM users WHERE name REGEXP '^[A-M]';  -- 匹配以 A 到 M 开头的名字

匹配数字:

sql 复制代码
SELECT * FROM orders WHERE order_number REGEXP '[0-9]';  -- 匹配包含数字的订单号

匹配多个选项:

sql 复制代码
SELECT * FROM products WHERE category REGEXP 'electronics|furniture';  -- 匹配电子产品或家具
  1. 常用正则表达式符号
sql 复制代码
^:匹配字符串的开始。
$:匹配字符串的结束。
.:匹配任意单个字符。
*:匹配前一个字符零次或多次。
+:匹配前一个字符一次或多次。
?:匹配前一个字符零次或一次。
|:表示"或"操作。
[]:匹配方括号内的任意单个字符,例如 [abc] 匹配 a、b 或 c。

4. 不区分大小写

默认情况下,REGEXP 是不区分大小写的。如果需要区分大小写,可以使用 BINARY 关键字:

sql 复制代码
SELECT * FROM users WHERE BINARY name REGEXP '^[A-M]';  -- 匹配以 A 到 M 开头的名字,区分大小写

5. 注意事项

使用 REGEXP 可能会影响性能,特别是在大型数据集上。

需要确保正则表达式的正确性,以避免意外匹配。

示例查询

sql 复制代码
SELECT * FROM employees WHERE email REGEXP '@example\.com$';  -- 匹配所有在 example.com 域名下的电子邮件
相关推荐
kexnjdcncnxjs14 分钟前
mysql如何优化小表的查询索引_mysql全表扫描与索引代价对比
jvm·数据库·python
Filwaod34 分钟前
互联网大厂Java面试实战:Spring+Redis+MySQL+JVM场景问答深度解析
jvm·spring boot·redis·mysql·java面试·技术面试·互联网大厂
一只专注api接口开发的技术猿40 分钟前
京东商品实时监控选品实战:用 Open Claw API 快速搭建自动化工具
运维·数据库·自动化
万事大吉CC44 分钟前
【7】Django 类视图实战指南:如何高效引用与配置
数据库·sqlite
木土雨成小小测试员1 小时前
Python测试开发之后端二完结
数据库·python·sqlite
szccyw01 小时前
如何从SQL提取年或月数据_运用YEAR与MONTH提取函数
jvm·数据库·python
重生之小比特1 小时前
【MySQL 数据库】基本查询
android·数据库·mysql
罗超驿1 小时前
4.MySQL数据表操作与CRUD详解:从建表、插入到查询的全流程
数据库·mysql
2601_954971131 小时前
没有SQL基础能学数据分析吗?先学什么更合适
数据库·sql·数据分析
page_qiu1 小时前
高并发&大数据量&毫秒级响应系统设计方案
java·前端·数据库·高并发·高响应