今天寫個動態腳本,需要把資料庫裡面包含“USER_"的表刪除掉,突然想不起來如何搜索通配字元了,趕緊查查MSDN,整理了下模糊查詢的知識點,留著以後查閱用。 LIKE模糊查詢的通配符 通配符 說明 示例 % 包含零個或多個字元的任意字元串。 WHERE title LIKE '%computer%' ...
今天寫個動態腳本,需要把資料庫裡面包含“USER_"的表刪除掉,突然想不起來如何搜索通配字元了,趕緊查查MSDN,整理了下模糊查詢的知識點,留著以後查閱用。
LIKE模糊查詢的通配符
通配符 |
說明 |
示例 |
% |
包含零個或多個字元的任意字元串。 |
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 的所有作者的姓氏。 |
搜索通配符字元
在模糊查詢中,我們需要查詢包含通配符%, _之類的字元,比如我需要查詢表名包含"user_"的表,我們可以用下麵兩種方法。
SELECT * FROM sysobjects WHERE xtype = 'U' AND name LIKE '%user/_%' ESCAPE '/'
SELECT * FROM sysobjects WHERE xtype = 'U' AND name LIKE '%user[_]%'
將通配符作為文字使用
可以將通配符模式匹配字元作為文字字元使用。若要將通配符作為文字字元使用,請將通配符放在方括弧中。下表顯示了幾個使用 LIKE 關鍵字和 [ ]通配符的示例。
符號 |
含義 |
LIKE '5[%]' |
5% |
LIKE '[_]n' |
_n |
LIKE '[a-cdf]' |
a、b、c、d 或 f |
LIKE '[-acdf]' |
-、a、c、d 或 f |
LIKE '[ [ ]' |
[ |