前言
MySQL的regexp与LIKE语句非常类似,大部分功能都可以相互替补。之前一直没有使用过,最近在阅读《MySQL必知必会》第九章时,看到了这个内容,在此做下笔记记录一下。
在此之前,首先建立对应的数据表,ddl与dml如下:
create table if not exists test_db.products
(
id int auto_increment
primary key,
prod_name varchar(20) not null
);
INSERT INTO test_db.products (id, prod_name) VALUES (1, 'JetPack 1000');
INSERT INTO test_db.products (id, prod_name) VALUES (2, 'JetPack 2000');
INSERT INTO test_db.products (id, prod_name) VALUES (3, '1 ton anvil');
INSERT INTO test_db.products (id, prod_name) VALUES (4, '2 ton anvil');
INSERT INTO test_db.products (id, prod_name) VALUES (5, 'TNT (1 stick)');
INSERT INTO test_db.products (id, prod_name) VALUES (6, '.5 ton anvil');
data:image/s3,"s3://crabby-images/fee9d/fee9d84df7bff9e586bf90314ac66a1620d48886" alt="请输入图片描述"
常用指令
由于regexp与LIKE的高度相似性,所以学习时以常用的LIKE的指令作为对比学习,有助于记忆。
基本字符匹配
- 全文字匹配
select *
from products
where prod_name regexp '1000';
data:image/s3,"s3://crabby-images/b5afb/b5afb0f218b550f85a59e69c6a58400b0d67b093" alt="请输入图片描述"
- 模糊匹配
类似于LIKE语句的 '_'(下划线)单字符匹配。模糊匹配单个字符。
select *
from products
where prod_name regexp '.000';
data:image/s3,"s3://crabby-images/625cd/625cd65a86bb79dc9910637c677c28974ac6beaa" alt="请输入图片描述"
OR 匹配
select *
from products
where prod_name regexp '1000|2000';
data:image/s3,"s3://crabby-images/fe28f/fe28f9db655a52eeeb387e4c79bad2785fc50723" alt="请输入图片描述"
匹配几个字符之一
- 正确用法
select *
from products
where prod_name regexp '[123] ton';
data:image/s3,"s3://crabby-images/ecfcf/ecfcfb7d4efcf4a5741c8fba650f0b830e46bf7e" alt="请输入图片描述"
- 错误示例
正则表达式可以用[]
包含内容或者|
竖线 表示或
,但如果使用下面的用法,不能获得正确的结果,因为在最后一个'或'时,MySQL会理解成3 ton
。得到不同的结果。
select *
from products
where prod_name regexp '1|2|3 ton';
data:image/s3,"s3://crabby-images/f0fb7/f0fb784285db8711bc4332fa50ab45bb906be3a8" alt="请输入图片描述"