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 用\,写成\%或\_)

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

相关推荐
ChineHe20 小时前
Redis数据类型篇002_详解Strings核心命令与存储结构
数据库·redis·缓存
清水白石00820 小时前
《从零到进阶:Pydantic v1 与 v2 的核心差异与零成本校验实现原理》
数据库·python
电商API&Tina20 小时前
京东 API 数据采集接口接入与行业分析
运维·服务器·网络·数据库·django·php
柠檬叶子C20 小时前
PostgreSQL 忘记 postgres 密码怎么办?(已解决)
数据库·postgresql
864记忆21 小时前
Qt创建连接注意事项
数据库·qt·nginx
毕设十刻21 小时前
基于Vue的迅读网上书城22f4d(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
薛定谔的猫19821 天前
Langchain(十二)LangGraph 实战入门:用流程图思维构建 LLM 工作流
数据库·microsoft
坐吃山猪1 天前
ChromaDB02-代码实战
数据库·向量数据库·chromadb
摇滚侠1 天前
MySQL 中 utf8mb4 字符集,字母a占几个字节,一个汉字占几个字节 / MySQL 中 utf8mb3 字符集,字母a占几个字节,一个汉字占几个字节
数据库·mysql
ChineHe1 天前
Redis数据类型篇001_数据类型梳理与选择指南
数据库·redis·缓存