MySQL通配符%和_用于LIKE模糊匹配,%匹配任意字符,_匹配单个字符,可通过反斜杠或ESCAPE自定义转义符处理特殊字符,结合固定字符实现精准查询,复杂场景可用REGEXP正则替代。

MySQL 中的通配符主要用于 LIKE 或 NOT LIKE 操作中进行模糊匹配。最常见的通配符是 % 和 _,它们可以与其他符号(如转义字符、普通字符、正则表达式等)组合使用,实现更精确的查询控制。
1. 基本通配符说明
● %:匹配任意数量的字符(包括零个字符) ● _:匹配单个字符例如:
SELECT * FROM users WHERE name LIKE 'a%'; -- 匹配以 a 开头的所有名字 SELECT * FROM users WHERE name LIKE 'a_b'; -- 匹配 a 开头、b 结尾,中间恰好一个字符的名字
2. 使用反斜杠 \ 转义特殊字符
当需要匹配包含 % 或 _ 的实际字符串时,必须使用转义字符避免被解释为通配符。MySQL 默认使用反斜杠 \ 作为转义字符。
示例:
-- 查找名字中包含下划线 '_' 的记录 SELECT * FROM users WHERE name LIKE 'test\_name';-- 查找名字以 '%' 结尾的记录 SELECT * FROM users WHERE name LIKE 'value\%';
上述语句中,\_ 表示匹配字面意义的下划线,\% 表示匹配百分号。
3. 自定义 ESCAPE 子句指定转义符
除了默认的反斜杠,还可以通过 ESCAPE 关键字自定义转义符号,提高可读性或避免冲突。
示例:
-- 使用 | 作为转义符 SELECT * FROM users WHERE name LIKE 'score|%' ESCAPE '|'; -- 匹配以 "score%" 开头的名字 SELECT * FROM users WHERE name LIKE 'data|_' ESCAPE '|'; -- 匹配 "data_" 字符串
这样写可以让意图更清晰,尤其是在处理大量特殊字符时。
4. 与普通字符组合使用
通配符通常与固定字符结合,实现部分匹配:
- 'abc%':匹配以 abc 开头的任意字符串
- '%xyz':匹配以 xyz 结尾的字符串
- '%test_%':匹配包含 "test_" 且后面至少还有一个字符的内容
- 'A_C%':匹配 A 开头,C 是第三个字符,后面任意内容的字符串
5. 与正则表达式对比(REGEXP)
虽然 LIKE 支持通配符,但功能有限。若需更复杂的模式匹配,可使用 REGEXP 或 RLIKE,它支持更丰富的符号组合,如:
SELECT * FROM users WHERE name REGEXP '^a.*z$'; -- 以 a 开头,z 结尾 SELECT * FROM users WHERE name REGEXP 'test[0-9]'; -- 匹配 test 后跟一个数字
注意:REGEXP 不使用 % 和 _,而是采用标准正则语法,因此不能混用 LIKE 通配符。
6. 实际应用场景举例
假设有一个日志表 log_table,字段 info 存储格式如 "error_2024", "warning_102" 等:
-- 查找所有 error_ 开头后接任意字符的数据 SELECT * FROM log_table WHERE info LIKE 'error\_%' ESCAPE '\';-- 或者使用 ESCAPE 明确声明 SELECT * FROM logtable WHERE info LIKE 'error|%' ESCAPE '|';
这里的关键是把下划线转义,否则 error_% 会被理解为 "error" 加一个任意字符再加任意内容,造成误匹配。
基本上就这些。合理搭配通配符和转义机制,能有效提升模糊查询的准确性。










