眾所周知,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 '!'
