搜索条件中的模式匹配,及包含关键字条件匹配
2010-01-26 13:52
197 查看
搜索条件中的模式匹配
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)。
下列查询在 authors 表中查找所有区号为 415 的电话号码:
SELECT phone FROM pubs.dbo.authors WHERE phone LIKE '415%'
可以用同样的通配符使用 NOT LIKE。若要在 authors 表中查找区号不是 415 的所有电话号码,请使用下列等价查询中的任意一个:
SELECT phone FROM pubs.dbo.authors WHERE phone NOT LIKE '415%' -- Or SELECT phone FROM pubs.dbo.authors WHERE NOT phone LIKE '415%'
IS NOT NULL 子句可与通配符和 LIKE 子句结合使用。例如,下列查询从 authors 表中检索以 415 开头且 IS NOT NULL 的所有电话号码:
USE pubs SELECT phone FROM authors WHERE phone LIKE '415%' and phone IS NOT NULL
重要[/b] 包含 LIKE 关键字的语句的输出结果取决于安装过程中所选的排序次序。有关不同排序次序所产生的影响的信息,请参见排序规则。
可用于 text 列的 WHERE 条件只有 LIKE、IS NULL 或 PATINDEX。
不与 LIKE 一同使用的通配符将解释为常量而非模式,换言之,这些通配符仅代表其本身的值。下列查询试图查找只由四个字符 415% 组成的电话号码。该查询并不会查找以 415 开头的电话号码。有关常量的更多信息,请参见使用常量。
SELECT phone FROM pubs.dbo.authors 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, or f |
LIKE '[-acdf]' | -, a, c, d, or f |
LIKE '[ [ ]' | [ |
LIKE ']' | ] |
=========
其实就是帮助文档里的,怕到时候忘了。
相关文章推荐
- PHP微信开发模式,搜索已发送图文,匹配关键字回复
- 搜索条件中的模式匹配
- PHP使用微信开发模式实现搜索已发送图文及匹配关键字回复的方法
- SQL查询用Like搜索条件中的模式匹配
- SQL查询用Like搜索条件中的模式匹配
- 字符串关键字搜索匹配提取处理算法
- EditText搜索关键字,返回结果匹配关键字改变颜色
- mysql 搜索条件包含与被包含
- 运用组合模式实现复合搜索条件构建
- Jquery插件仿百度搜索关键字自动匹配功能
- 谷歌面试题:给定一个数据流,其中包含无穷尽的搜索关键字(比如,人们在谷歌搜索时不断输入的关键字) 。如何才能从这个无穷尽的流中随机的选取 1000 个关键字?
- jQuery实现搜索关键字自动匹配提示方法
- 基本上包含了Foudation框架内的所有函数和方法。 使用方法:全选,自己建一个文本类的文件,如果要使用某个方法却想不起来方法名,直接在文本中搜索关键字即可。
- 14-使用自定义的高亮标签和搜索title和content中包含搜索关键字的内容
- 使用ES做简单的时间条件过滤+模糊查询+精确匹配+关键字排除
- 字符串多模式精确匹配(脏字/敏感词汇搜索算法)——TTMP算法 之理论如此
- 字符串模式匹配算法(字符串搜索)
- 采用多线程和生产者消费者模式来实现对于一个目录以及所有子目录下的文件内容的搜索,打印出包含指定关键字的行.
- 如何使用grep查询出不包含某匹配模式的文件
- [置顶] Android仿微信搜索,Recyclerview+关键字动态匹配筛选变色效果(Edittext+Recyclerview)