这是命令行操作MySQL数据库系列博客的第十五篇,今天这篇博客记录LIKE模糊查询。
简介
当我们只想用字符串中间的一部分特征查找含有特征字串的信息时,MySQL提供了关键字LIKE来实现模糊查询,需要使用通配符。
就比如,我们只记得一个朋友的姓是张,却忘记名字了,那么我们就可以使用模糊查询,只查询张,就可以将它名字信息查询出来。
通配符
在MySQL中,字符串必须加上单引号(’’)和双引号(″″)。由于关键字LIKE可以实现模糊查询,因此该关键字后面的字符串参数除了可以使用完整的字符串外,还可以包含通配符。LIKE关键字支持的通配符如下表所示。
符号 | 功能描述 |
---|---|
_ | 该通配符值能匹配单个字符 |
% | 该通配符可以匹配任意长度的字符串,即可以是0个字符,也可以是1个字符,也可以是很多字符 |
使用语法
-
LIKE
select * from 表名 where 字段名 LIKE 模糊匹配的数据;
select * from 表名 where 字段名 LIKE 模糊匹配的数据 AND 字段名 LIKE 模糊匹配的数据;
-
NOT LIKE
select * from 表名 where 字段名 NOT LIKE 模糊匹配的数据;
例:
创建一张表,并插入数据:
create table like_test(id int PRIMARY KEY AUTO_INCREMENT, name varchar(32));
insert into like_test(name) values('abc'), ('bcd'), ('cde'), ('一二三'), ('二三四'), ('三四五');
通配符 ’ % ’
匹配0个或多个字符。
-
查询数据中含有’b’字母所有数据
select * from like_test where name LIKE '%b%';
-
查询数据中即含有’b’又含有’c’字母的所有数据
mysql> select * from like_test where name LIKE '%b%' AND name LIKE '%c%';
-
查询数据中以’一’开头的所有数据
select * from like_test where name LIKE '一%';
通配符 ’ _ ’
只匹配单个字符。
-
查询数据中已’c’在中间,左右两边各含有一个字符的数据
select * from like_test where name LIKE '_c_';
-
查询数据中以’三’开头,后面还有两个汉字的数据
select * from like_test where name LIKE 'c__';
-
查询第二个字符是’三’的数据
select * from like_test where name LIKE '_三%';
NOT LIKE
查询符合条件之外的所有数据。
-
查询数据中不含有’三’的所有数据
select * from like_test where name NOT LIKE '%三%';
-
查询数据中不包括第三个数据是’三’的所有数据
select * from like_test where name NOT LIKE '__三%';
模糊查询整型数据
模糊查询也支持查询其它类型的数据,但是它底层始终都是以字符串的方式进行查询。
-
查询数据中以’1’开头的数据
select * from like_test where id LIKE '1%';
-
查询除’1’开头之外的所有数据
select * from like_test where id NOT LIKE '1%';
-
查询所有数据
select * from like_test where id LIKE '%%';
总结:
从上面所列举出来的例子可以知道,LIKE模糊查询并不难,搞懂通配符的使用方式,再结合LIKE使用即可。需注意,如果不使用通配符的话是无法查询到结果的。