众所周知,T-SQL中LIKE运算符使用%符号表示通配符。很多时候可能需要查询包含有%的数据,比如需要查询字段coupon中含有5%的数据。那么如何使用已经有百分号(%)符号的LIKE搜索字符串呢?
从MSDN中可以找到,Like 中的通配符包含有:
通配符 |
Description |
示例 |
% |
包含零个或多个字符的任意字符串。 |
WHERE title LIKE '%computer%' 将查找在书名中任意位置包含单词 "computer" 的所有书名。 |
_(下划线) |
任何单个字符。 |
WHERE au_fname LIKE '_ean' 将查找以 ean 结尾的所有 4 个字母的名字(Dean、Sean 等)。 |
[ ] |
指定范围 ([a-f]) 或集合 ([abcdef]) 中的任何单个字符。 |
WHERE au_lname LIKE '[C-P]arsen' 将查找以 arsen 结尾并且以介于 C 与 P 之间的任何单个字符开始的作者姓氏,例如 Carsen、Larsen、Karsen 等。 在范围搜索中,范围包含的字符可能因排序规则的排序规则而异。 |
[^] |
不属于指定范围 ([a-f]) 或集合 ([abcdef]) 的任何单个字符。 |
WHERE au_lname LIKE 'de[^l]%' 将查找以 de 开始并且其后的字母不为 l 的所有作者的姓氏。 |
那么该将通配符作为文字使用呢?
- 方法1 使用括号,比如75%
WHERE MyCol LIKE '%75[%]%'
下表显示了几个使用 LIKE 关键字和 [ ] 通配符的示例。
符号 |
含义 |
LIKE '5[%]' |
5% |
LIKE '[_]n' |
_n |
LIKE '[a-cdf]' |
a、b、c、d 或 f |
LIKE '[-acdf]' |
-、a、c、d 或 f |
LIKE '[ [ ]' |
[ |
LIKE ']' |
] |
LIKE 'abc[_]d%' |
abc_d 和 abc_de |
LIKE 'abc[def]' |
abcd、abce 和 abcf |
方法2 使用 ESCAPE 子句
SELECT *
FROM table
WHERE MyCol LIKE '%75!%%'
ESCAPE '!'