sql通配符(大量查找搜索索引)

SQL 通配符可以理解成数据库里的 "万能钥匙" 或 "模糊匹配的小工具" ,专门用来在查询时做模糊搜索,搭配 LIKE 关键字使用,能代替一个或多个字符,解决 "记不清完整内容,只想找相似数据" 的问题。

下面用最通俗的话,讲清楚常用的通配符和用法,还会配生活中的例子类比:

一、最常用的两个核心通配符

1. %:匹配任意数量的任意字符(包括 0 个)大量搜索

可以把它想象成 "输入法的 * 号",比如搜 "苹 %",就会出来苹果、苹果手机、平安果等所有以 "苹" 开头的内容。

举 SQL 例子

假设你有一张用户表(user),里面有姓名(name)字段,想找所有姓 "张" 的用户:

复制代码

SELECT * FROM user WHERE name LIKE '张%';

  • 匹配结果:张三、张三丰、张无忌、张(单字名)都能被找到。

再比如,想找姓名里包含 "小" 字的用户:

复制代码

SELECT * FROM user WHERE name LIKE '%小%';

  • 匹配结果:小李、张小胖、王二小都能被找到。
2. _:匹配一个且仅一个任意字符 单一搜索

这个是 "严格的单字占位符",只能替一个字,多了少了都不行。

举 SQL 例子

想找姓名是 "张"+ 一个字的用户(比如张三、张四,排除张三丰):

复制代码

SELECT * FROM user WHERE name LIKE '张_';

  • 匹配结果:只有 "张三""张五" 这种两个字的张姓用户,三个字的 "张三丰" 会被排除。

再比如,想找名字是 3 个字,且中间是 "小" 的用户:

复制代码

SELECT * FROM user WHERE name LIKE '_小_';

  • 匹配结果:李小龙、王小花、张小胖都能被找到,而 "小敏"(两个字)、"李大小花"(四个字)会被排除。

下面的 SQL 语句选取 name 以 "G" 开始,然后是一个任意字符,然后是 "o",然后是一个任意字符,然后是 "le" 的所有网站:

SELECT * FROM Websites

WHERE name LIKE 'G_o_le';

二、其他常见通配符(依数据库类型略有差异)

这些是 "细分场景的工具",不同数据库(比如 MySQL、SQL Server)支持度不同,最常用的是 MySQL 的[]和[^]:

1. []:匹配括号里的任意一个字符

相当于 "选择题",只能选括号里的某一个字。

例子(MySQL/SQL Server)

想找姓 "张",第二个字是 "三" 或 "五" 的用户:

复制代码

SELECT * FROM user WHERE name LIKE '张[三五]';

  • 匹配结果:张三、张五会被找到,张四、张三丰被排除。
2. [^](MySQL)/ !(SQL Server):匹配不在括号里的任意一个字符

和[]相反,是 "排除法"。

例子(MySQL)

想找姓 "张",第二个字不是 "三" 的两个字用户:

SELECT * FROM user WHERE name LIKE '张[^三]';

  • 匹配结果:张四、张五会被找到,张三被排除。

下面的 SQL 语句选取 name 以 "G"、"F" 或 "s" 开始的所有网站:

SELECT * FROM Websites

WHERE name REGEXP '^[GFs]';

下面的 SQL 语句选取 name 以 A 到 H 字母开头的网站:

SELECT * FROM Websites

WHERE name REGEXP '^[A-H]';

下面的 SQL 语句选取 name 不以 A 到 H 字母开头的网站:

SELECT * FROM Websites

WHERE name REGEXP '^[^A-H]';

三、关键提醒

  1. 通配符必须和 LIKE 关键字搭配用,不能单独用;
  1. % 能匹配 0 个字符,所以'张%'能匹配单字名 "张",而'张_'不行;
  1. 如果想匹配通配符本身(比如数据里真的有 % 或_),需要加转义符(比如 MySQL 用\,写成\%或\_)

总结一下:%是 "多字通配",_是 "单字通配",[]是 "指定范围通配",用它们就能轻松实现模糊查询,不用死记完整的字段内容啦。

相关推荐
斐硕人1 小时前
SQL滚动求和
数据库·sql·mysql·maxcompute
爬山算法1 小时前
Redis(135)Redis的网络模型是什么?
网络·数据库·redis
L.EscaRC2 小时前
Redis大Key与内存不足问题深度解析与应对策略
数据库·redis·缓存
雲烟2 小时前
Qt SQLite在I.mx8上使用问题
数据库·qt·i.mx8
TDengine (老段)2 小时前
TDengine 转换函数 CAST 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ2 小时前
java实现校验sql中,表字段在表里是否都存在,不存在的给删除掉
java·sql
苦瓜炒蛋挞3 小时前
小迪安全第二十二天-安全开发-PHP应用&数据库操作&留言板功能&第三方插件
数据库·网络安全·php·小迪安全
chushiyunen3 小时前
redis命令 geo(对地理坐标的支持)
数据库·redis·缓存
baivfhpwxf20233 小时前
删除数据表SQL,不是删除数据,是删除表结构
数据库·sql