SQL SERVER 的模糊查詢 LIKE


今天寫個動態腳本,需要把數據庫里面包含“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 '[ [ ]'

[


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM