格式: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...)

技术
今日推荐
下载桌面版
GitHub
百度网盘(提取码:draw)
Gitee
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:766591547
关注微信