Sqlserver:Like模式匹配

LIKE 关键字搜索与指定模式匹配的字符串、日期或时间值。有关详细信息,请参阅。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 的所有电话号码:

copycode.gif复制代码
SELECT Phone
FROM AdventureWorks.Person.Contact
WHERE Phone LIKE '415%'

可以将 NOT LIKE 与同样的通配符结合使用。若要查找 Contact 表中区号不是 415 的所有电话号码,请使用下列等价查询中的任意一个:

copycode.gif复制代码
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 的所有电话号码:

copycode.gif复制代码
USE AdventureWorks;
GO
SELECT Phone
FROM Person.Contact
WHERE Phone LIKE '415%' and Phone IS NOT NULL
note.gif重要事项:
包含 LIKE 关键字的语句的输出取决于安装过程中选择的排序顺序。有关不同的排序顺序所产生的影响的详细信息,请参阅使用排序规则

可以在 text 列中使用的唯一 WHERE 条件是 LIKE、IS NULL 或 PATINDEX。

不与 LIKE 一同使用的通配符将解释为常量而非模式,换言之,这些通配符仅代表其本身的值。以下查询试图查找只由四个字符 415% 组成的电话号码。该查询将不会查找以 415 开头的电话号码。有关常量的详细信息,请参阅常量(数据库引擎)

copycode.gif复制代码
SELECT Phone
FROM AdventureWorks.Person.Contact
WHERE Phone = '415%'

使用通配符时应着重考虑的另一个问题是对性能的影响。如果表达式以通配符开头,就不能使用索引(就如同给定了姓名 "%mith" 而非 "Smith" 时,将无法知道应从电话簿的哪一页开始查找)。表达式中间或结尾处的通配符不妨碍索引的使用(就如同在电话簿中一样,如果姓名为 "Samuel%",则不论 Samuels 和 Samuelson 是否都在电话簿上,都知道该从何处开始查找。)

collapse.gif搜索通配符字符

可以搜索通配符字符。有两种方法可指定平常用作通配符的字符:

  • 使用 ESCAPE 关键字定义转义符。在模式中,当转义符置于通配符之前时,该通配符就解释为普通字符。例如,要搜索在任意位置包含字符串 5% 的字符串,请使用:

    copycode.gif复制代码
    WHERE ColumnA LIKE '%5/%%' ESCAPE '/'
    在上述 LIKE 子句中,前导和结尾百分号 (%) 解释为通配符,而斜杠 (/) 之后的百分号解释为字符 %。
  • 在方括号 ([ ]) 中只包含通配符本身。若要搜索破折号 (-) 而不是用它指定搜索范围,请将破折号指定为方括号内的第一个字符:

    copycode.gif复制代码
    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 开头且具有零个或多个尾随空格的所有行。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值