SQL实现模糊查询的四种方法总结

目录

一、一般模糊查询

二、利用通配符查询

[1. _ 表示任意的单个字符](#1. _ 表示任意的单个字符)

[2. % 表示匹配任意多个任意字符](#2. % 表示匹配任意多个任意字符)

[3. [ ]表示筛选范围](#3. [ ]表示筛选范围)

[4. 查询包含通配符的字符串](#4. 查询包含通配符的字符串)


一、一般模糊查询

  1. 单条件查询
sql 复制代码
//查询所有姓名包含"张"的记录

select * from student where name like '张'
  1. 多条件查询
sql 复制代码
//查询所有姓名包含"张",地址包含四川的记录

select * from student where name like '张' and address like '四川'

//查询所有姓名包含"张",或者地址包含四川的记录

select * from student where name like '张' or address like '四川'

二、利用通配符查询

通配符:_ 、% 、[ ]

1. _ 表示任意的单个字符

sql 复制代码
//查询所有名字姓张,字长两个字的记录

select * from student where name like '张_'

//查询所有名字姓张,字长三个字的记录

select * from student where name like '张__'

2. % 表示匹配任意多个任意字符

sql 复制代码
//查询所有名字姓张,字长不限的记录

select * from student where name like '张%'

//查询所有名字姓张,字长两个字的记录

select * from student where name like '张%'and len(name) = 2

3. [ ]表示筛选范围

sql 复制代码
//查询所有名字姓张,第二个为数字,第三个为燕的记录

select * from student where name like '张[0-9]燕'

//查询所有名字姓张,第二个为字母,第三个为燕的记录

select * from student where name like '张[a-z]燕'

//查询所有名字姓张,中间为1个字母或1个数字,第三个为燕的名字。字母大小写可以通过约束设定,不区分大小写

select * from student where name like '张[0-9a-z]燕'

//查询所有名字姓张,第二个不为数字,第三个为燕的记录

select * from student where name like '张[!0-9]燕' 

//查询名字除了张开头妹结尾中间是数字的记录

select * from student where name not like '张[0-9]燕'

4. 查询包含通配符的字符串

sql 复制代码
//查询姓名包含通配符%的记录

 select * from student where name like '%[%]%'                //通过[]转义

//查询姓名包含[的记录

 select * from student where name like '%/[%' escape '/'    //通过指定'/'转义

//查询姓名包含通配符[]的记录

 select * from student where name like '%/[/]%' escape '/'    //通过指定'/'转义

到此这篇关于SQL实现模糊查询的四种方法总结的文章就介绍到这了。

相关推荐
ma_king2 小时前
入门 java 和 数据库
java·数据库·后端
jiayou645 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
随风飘的云6 小时前
mysql的innodb引擎对可重复读做了那些优化,可以避免幻读
mysql
NineData17 小时前
NineData 迁移评估功能正式上线
数据库·dba
NineData1 天前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
阿里云大数据AI技术1 天前
用 SQL 调大模型?Hologres + 百炼,让数据开发直接“对话”AI
sql·llm
赵渝强老师1 天前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石1 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou643 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库