- 我的电脑系统:Windows 10 64位
- SQL Server 软件版本: SQL Server 2014 Express
本篇博客里面使用了 scott
库,如何你现在还没有添加这个库到你的服务器里面,请在查看本篇博客前,访问这篇博文来在你的服务器里面附加scott
库。
怎样编写模糊查询语句
1
2
3
4
5
6
| select * from emp where ename like '%A%'
--ename只要含有字母A就输出
select * from emp where ename like 'A%'
--ename只要首字母是A的就输出
select * from emp where ename like '%A'
--ename只要尾字母是A的就输出
|
data:image/s3,"s3://crabby-images/1d223/1d2233001e591ba36cbb3ad688520aeac77a7fab" alt="Alt text"
data:image/s3,"s3://crabby-images/b896f/b896f9169b9689b8b44dfd13ce4f2219cd45ac49" alt="Alt text"
data:image/s3,"s3://crabby-images/86ac7/86ac76d6d85b9432934b6357d74cc43eb44688ba" alt="Alt text"
1
2
| select * from emp where ename like '_A%'
--ename只要第二个字母是A的就输出
|
data:image/s3,"s3://crabby-images/93d98/93d98183b03679f16cf2163c032eeb1fb55c0440" alt="Alt text"
1
2
| select * from emp where ename like '_[A-F]%'
--把ename中第二个字符是A或者B或者C或者D或者E或者F的记录输出
|
data:image/s3,"s3://crabby-images/32579/325793f17771228714051e07222f4b0cebd055ef" alt="Alt text"
1
2
| select * from emp where ename like '_[^A-F]%'
--把ename中第二个字符不是A也不是B也不是C也不是D也不是E也不是F的记录输出
|
data:image/s3,"s3://crabby-images/559c4/559c45d213ee11c630524d75507bf4717bc7f3c3" alt="Alt text"
创建一个 student
表。(预备操作)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
| create table student
(
name nvarchar(20) null,
age int
);
insert into student values ('张三', 68);
insert into student values ('Tom', 66);
insert into student values ('a_b', 22);
insert into student values ('c%d', 44);
insert into student values ('abc_fe', 56);
insert into student values ('haobin', 25);
insert into student values ('HapBin', 88);
insert into student values ('c%', 66);
insert into student values ('long''s', 100)
select * from student;
|
data:image/s3,"s3://crabby-images/53239/53239b2bfe9893f2d03f1fb76797079d82e7aa0d" alt="Alt text"
1
2
3
4
| select * from student where name like '%\%%' escape '\'
--把name中包含有%的输出
select * from student where name like '%\_%' escape '\'
--把name中包含有_的输出
|
data:image/s3,"s3://crabby-images/9c625/9c6251a37825f4a0ee90e0d96d0ac8504e3cae1d" alt="Alt text"
data:image/s3,"s3://crabby-images/20289/2028956c4760c198ff7ea2bc0b092bb52c640324" alt="Alt text"
总结: 通配符:
格式: select 字段的集合 from 表名 where 某个字段的名字 like 匹配的条件
匹配的条件通常含有通配符
%
_
(这个是下划线,不是减号)
[a-f]
a
到 f
中的任意单个字符。只能是a
、b
、c
、d
、e
、f
中的任意一个字符
[a, f]
[^a-c]
注意:
- 匹配的内容必须使用单引号括起来。不能省略,也不能改用双引号。
escape '\'
里面 escape
后面 ''
里面的\
字符就自定义的:通配符。它可以替换成其他的字符(比如:a
、b
、m
等等)。