SQL通配符使用。
SQL2005中使用通配符 % _ [ ] ^
LIKE 关键字搜索与指定模式匹配的字符串、日期或时间值。有关详细信息,请参阅数据类型 (Transact-SQL)。LIKE 关键字使用常规表达式包含值所要匹配的模式。模式包含要搜索的字符串,字符串中可包含四种通配符的任意组合。
通配符 | 含义 |
---|---|
% |
包含零个或多个字符的任意字符串。 |
_ |
任何单个字符。 |
[ ] |
指定范围(例如 [a-f])或集合(例如 [abcdef])内的任何单个字符。 |
[^] |
不在指定范围(例如 [^a - f])或集合(例如 [^abcdef])内的任何单个字符。 |
请将通配符和字符串用单引号引起来,例如:
- LIKE ‘Mc%’ 将搜索以字母 Mc 开头的所有字符串(如 McBadden)。
- LIKE ‘%inger’ 将搜索以字母 inger 结尾的所有字符串(如 Ringer 和 Stringer)。
- LIKE ‘%en%’ 将搜索任意位置包含字母 en 的所有字符串(如 Bennet、Green 和 McBadden)。
- LIKE ‘_heryl’ 将搜索以字母 heryl 结尾的所有六个字母的名称(如 Cheryl 和 Sheryl)。
- LIKE ‘[CK]ars[eo]n’ 将搜索 Carsen、Karsen、Carson 和 Karson(如 Carson)。
- LIKE ‘[M-Z]inger’ 将搜索以字母 inger 结尾、以 M 到 Z 中的任何单个字母开头的所有名称(如 Ringer)。
- LIKE ‘M[^c]%’ 将搜索以字母 M 开头,并且第二个字母不是 c 的所有名称(如 MacFeather)。
此查询将查找
Contact
表中区号为 415 的所有电话号码:
SELECT Phone FROM AdventureWorks.Person.Contact WHERE Phone LIKE ’415%’ |
可以将 NOT LIKE 与同样的通配符结合使用。若要查找
Contact
表中区号不是 415 的所有电话号码,请使用下列等价查询中的任意一个:
SELECT Phone FROM AdventureWorks.Person.Contact WHERE Phone NOT LIKE ’415%’ – Or SELECT Phone FROM AdventureWorks.Person.Contact WHERE NOT Phone LIKE ’415%’ |
IS NOT NULL 子句可与通配符和 LIKE 子句结合使用。例如,此查询将从
Contact
表中检索以 415 开头且 IS NOT NULL 的所有电话号码:
USE AdventureWorks; GO SELECT Phone FROM Person.Contact WHERE Phone LIKE ’415%’ and Phone IS NOT NULL |
重要事项: |
---|
包含 LIKE 关键字的语句的输出取决于安装过程中选择的排序顺序。有关不同的排序顺序所产生的影响的详细信息,请参阅使用排序规则。 |
可以在 text 列中使用的唯一 WHERE 条件是 LIKE、IS NULL 或 PATINDEX。
不与 LIKE 一同使用的通配符将解释为常量而非模式,换言之,这些通配符仅代表其本身的值。以下查询试图查找只由四个字符 415% 组成的电话号码。该查询将不会查找以 415 开头的电话号码。有关常量的详细信息,请参阅常量(数据库引擎)。
SELECT Phone FROM AdventureWorks.Person.Contact WHERE Phone = ’415%’ |
使 用通配符时应着重考虑的另一个问题是对性能的影响。如果表达式以通配符开头,就不能使用索引(就如同给定了姓名 “%mith” 而非 “Smith” 时,将无法知道应从电话簿的哪一页开始查找)。表达式中间或结尾处的通配符不妨碍索引的使用(就如同在电话簿中一样,如果姓名为 “Samuel%”,则不论 Samuels 和 Samuelson 是否都在电话簿上,都知道该从何处开始查找。)
搜索通配符字符
可以搜索通配符字符。有两种方法可指定平常用作通配符的字符:
- 使用 ESCAPE 关键字定义转义符。在模式中,当转义符置于通配符之前时,该通配符就解释为普通字符。例如,要搜索在任意位置包含字符串 5% 的字符串,请使用:
WHERE ColumnA LIKE ‘%5/%%’ ESCAPE ‘/’
在上述 LIKE 子句中,前导和结尾百分号 (%) 解释为通配符,而斜杠 (/) 之后的百分号解释为字符 %。
- 在方括号 ([ ]) 中只包含通配符本身。若要搜索破折号 (-) 而不是用它指定搜索范围,请将破折号指定为方括号内的第一个字符:
WHERE ColumnA LIKE ’9[-]5′
下表显示了括在方括号内的通配符的用法。
符号 含义 LIKE ’5[%]‘
5%
LIKE ’5%’
5 后跟 0 个或多个字符的字符串
LIKE ‘[_]n’
_n
LIKE ‘_n’
an, in, on (and so on)
LIKE ‘[a-cdf]‘
a、b、c、d 或 f
LIKE ‘[-acdf]‘
-、a、c、d 或 f
LIKE ‘[ [ ]‘
[
LIKE ']‘
]
如果使用 LIKE 执行字符串比较,模式串中的所有字符(包括每个前导空格和尾随空格)都有意义。如果要求比较返回带有字符串
LIKE ‘abc ‘
(abc 后跟一个空格)的所有行,将不会返回列值为 abc(abc 后没有空格)的行。但是反过来,情况并非如此。可以忽略模式所要匹配的表达式中的尾随空格。如果要求比较返回带有字符串
LIKE ‘abc’
(abc 后没有空格)的所有行,将返回以 abc 开头且具有零个或多个尾随空格的所有行。
将通配符作为文字使用
可以将通配符模式匹配字符作为文字字符使用。若要将通配符作为文字字符使用,请将通配符放在方括号中。下表显示了几个使用 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 |
使用 ESCAPE 子句的模式匹配
可 搜索包含一个或多个特殊通配符的字符串。例如,customers 数据库中的 discounts 表可能存储含百分号 (%) 的折扣值。若要搜索作为字符而不是通配符的百分号,必须提供 ESCAPE 关键字和转义符。例如,一个样本数据库包含名为 comment 的列,该列含文本 30%。若要搜索在 comment 列中的任何位置包含字符串 30% 的任何行,请指定
WHERE comment LIKE ’0!%%’ ESCAPE ‘!’
之类的 WHERE 子句。如果未指定 ESCAPE 和转义符,则数据库引擎 将返回包含字符串 30 的所有行。
如 果 LIKE 模式中的转义符后面没有字符,则该模式无效并且 LIKE 返回 FALSE。如果转义符后面的字符不是通配符,则将放弃转义符并将该转义符后面的字符作为该模式中的常规字符处理。这包括百分号 (%)、下划线 (_) 和左括号 ([) 通配符(如果它们包含在双括号 ([ ]) 中)。另外,在双括号字符 ([]) 内,可以使用转义符并将插入符号 (^)、连字符 () 和右括号 (]) 转义。
转载自:http://losegoat.blog.163.com/blog/static/1822557200852111915785/
SQL 通配符
在搜索数据库中的数据时,SQL 通配符可以替代一个或多个字符。
SQL 通配符必须与 LIKE 运算符一起使用。
在 SQL 中,可使用以下通配符:
通配符 | 描述 |
---|---|
% | 替代一个或多个字符 |
_ | 仅替代一个字符 |
[charlist] | 字符列中的任何单一字符 |
[^charlist]
或者 [!charlist] |
不在字符列中的任何单一字符 |
原始的表 (用在例子中的):
Persons 表:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
1 | Adams | John | Oxford Street | London |
2 | Bush | George | Fifth Avenue | New York |
3 | Carter | Thomas | Changan Street | Beijing |
使用 % 通配符
例子 1
现在,我们希望从上面的 “Persons” 表中选取居住在以 “Ne” 开始的城市里的人:
我们可以使用下面的 SELECT 语句:
SELECT * FROM Persons WHERE City LIKE 'Ne%'
结果集:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
2 | Bush | George | Fifth Avenue | New York |
例子 2
接下来,我们希望从 “Persons” 表中选取居住在包含 “lond” 的城市里的人:
我们可以使用下面的 SELECT 语句:
SELECT * FROM Persons WHERE City LIKE '%lond%'
结果集:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
1 | Adams | John | Oxford Street | London |
使用 _ 通配符
例子 1
现在,我们希望从上面的 “Persons” 表中选取名字的第一个字符之后是 “eorge” 的人:
我们可以使用下面的 SELECT 语句:
SELECT * FROM Persons WHERE FirstName LIKE '_eorge'
结果集:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
2 | Bush | George | Fifth Avenue | New York |
例子 2
接下来,我们希望从 “Persons” 表中选取的这条记录的姓氏以 “C” 开头,然后是一个任意字符,然后是 “r”,然后是任意字符,然后是 “er”:
我们可以使用下面的 SELECT 语句:
SELECT * FROM Persons WHERE LastName LIKE 'C_r_er'
结果集:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
3 | Carter | Thomas | Changan Street | Beijing |
使用 [charlist] 通配符
例子 1
现在,我们希望从上面的 “Persons” 表中选取居住的城市以 “A” 或 “L” 或 “N” 开头的人:
我们可以使用下面的 SELECT 语句:
SELECT * FROM Persons WHERE City LIKE '[ALN]%'
结果集:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
1 | Adams | John | Oxford Street | London |
2 | Bush | George | Fifth Avenue | New York |
例子 2
现在,我们希望从上面的 “Persons” 表中选取居住的城市不以 ”A” 或 “L” 或 “N” 开头的人:
我们可以使用下面的 SELECT 语句:
SELECT * FROM Persons WHERE City LIKE '[!ALN]%'
结果集:
Id | LastName | FirstName | Address | City |
---|---|---|---|---|
3 | Carter | Thomas | Changan Street | Beijing |