今天写个动态脚本,须要把数据库里面包含“USER_"的表删除掉,忽然想不起来如何搜索通配字符了,赶忙查查MSDN,整理了下模糊查询的知识点,留着之后查阅用。数据库
LIKE模糊查询的通配符spa
通配符code |
说明blog |
示例排序 |
%ci |
包含零个或多个字符的任意字符串。字符串 |
WHERE title LIKE '%computer%' 将查找在书名中任意位置包含单词 "computer" 的全部书名。get |
_(下划线)it |
任何单个字符。table |
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 '[ [ ]' |
[ |