格式:SELECT 字段 FROM 表 WHERE 字段 Like 条件
SQL提供了四种匹配模式
1、_: 表示任意单个字符,用于匹配单个任意字符
例1:查询姓为张,名字只有2个字的用户
select * from user where name like '张_' (可匹配张兵、张大、张胜...)
2、%:表示任意0个或多个字符,用于匹配任意类型和长度的字符,中文需要使用两个百分号(%%)表示
例1:查询名字中含有兵的用户
select * from user where name like '%兵%' (可匹配王小兵、王兵、王兵西...)
例2:查询名字中含有小和兵的用户
select * from user where name like '%小%' and name like '%兵%' (可匹配小张兵、张兵小、张小兵等)
例3: 查询名字中含有小兵的用户
select * from user where name like '%小兵%' (可匹配王小兵、小兵张...)
例4:用户表user_profile(device_id , gender 性别, age 年龄, university 学校, province 省份)
请筛选出学校名满足以下所有条件的用户,输出关键字段信息:
以“北京”或“上海”开头;
以“学院”或“校区”结尾;
包含“职业”或“专科”或“成人”
select id ,device_id ,university
from user_profile
where (university like '北京%' or university like '上海%' )
and (university like '%学院' or university like '%校区' )
and (university like '%职业%' or university like '%专科%' or university like
'%成人%' )
3、[ ]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个
例1:查询姓为朱、张、王,名字为兵用户
select * from user where name like '[朱张王]兵' (可匹配朱兵、张兵、王兵)
例2:查询姓为张,名字为1-9的用户
select * from user where name like '张[1-5]' (可匹配张1、张2、张3...)
例3:查询姓为张,名字为a-z的用户
select * from user where name like '张[a-c]' (可匹配张a、张b、张c...)
4、[^ ] :表示不在括号所列之内的单个字符
例1:查询姓不为朱、张、王,名字为兵用户
select * from user where name like '[^朱张王]兵' (可匹配李兵、陈兵)
例2:查询姓为张,名字为1-5的用户
select * from user where name like '张[^1-5]' (可匹配张6、张7...)
例3:查询姓为张,名字不为a-c的用户
select * from user where name like '张[^a-c]' (可匹配张d、张e...)