搜索条件中的模式匹配
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 等等
LIKE '[a-cdf]'
a、b、c、d 或 f
LIKE '[-acdf]'
-、a、c、d 或 f
LIKE '[ [ ]'
[
LIKE ']'
]
如果使用 LIKE 执行字符串比较,模式串中的所有字符(包括每个前导空格和尾随空格)都有意义。如果请求比较返回包含字符串 "abc "(abc 后有一个空格)的所有行,则不会返回列值为 abc(abc 后没有空格)的行。但是反过来,情况并非如此。可以忽略模式所要匹配的表达式中的尾随空格。如果请求比较返回包含字符串 "abc"(abc 后没有空格)的所有行,则返回以 abc 开头并具有零个或多个尾随空格的所有行。
请参阅
其他资源
LIKE (Transact-SQL)
WHERE (Transact-SQL)
%(通配符 -- 需匹配的字符)(Transact-SQL)
[ ](通配符 - 要匹配的字符)(Transact-SQL)
[^](通配符 - 无需匹配的字符)(Transact-SQL)
_(通配符 - 匹配一个字符)(Transact-SQL)
PATINDEX (Transact-SQL)