【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 域名下的电子邮件
相关推荐
小Tomkk3 分钟前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
明月醉窗台1 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
沉到海底去吧Go1 小时前
【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案
数据库·qt·ocr·图片识别自动改名·图片区域识别改名·pdf识别改名
老纪的技术唠嗑局2 小时前
重剑无锋,大巧不工 —— OceanBase 中的 Nest Loop Join 使用技巧分享
数据库·sql
未来之窗软件服务2 小时前
JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟·东方仙盟数据库
寒山李白2 小时前
MySQL复杂SQL(多表联查/子查询)详细讲解
sql·mysql·子查询·多表联查
冰橙子id2 小时前
centos7编译安装LNMP架构
mysql·nginx·架构·centos·php
玛奇玛丶3 小时前
面试官:千万级订单表新增字段怎么弄?
后端·mysql
一只爱撸猫的程序猿4 小时前
构建一个简单的智能文档问答系统实例
数据库·spring boot·aigc
nanzhuhe4 小时前
sql中group by使用场景
数据库·sql·数据挖掘