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]';
三、关键提醒
- 通配符必须和 LIKE 关键字搭配用,不能单独用;
- % 能匹配 0 个字符,所以'张%'能匹配单字名 "张",而'张_'不行;
- 如果想匹配通配符本身(比如数据里真的有 % 或_),需要加转义符(比如 MySQL 用\,写成\%或\_)。
总结一下:%是 "多字通配",_是 "单字通配",[]是 "指定范围通配",用它们就能轻松实现模糊查询,不用死记完整的字段内容啦。