• 售前

  • 售后

热门帖子
入门百科

sqlserver 含糊查询常用方法

[复制链接]
钟情695 显示全部楼层 发表于 2021-10-26 12:28:12 |阅读模式 打印 上一主题 下一主题
搜索条件中的模式匹配
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

重要 包罗 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 ']' ]

如果使用 LIKE 进行字符串比较,模式字符串中的包括起始空格和/或尾随空格在内的所有字符都故意义。如果查询比较要求返回包罗"abc "(abc 后有一个空格)的所有行,则不会返回列值为"abc"(abc 后没有空格)行。但是反过来,情况并非云云。可以忽略模式所要匹配的表达式中的末端空格。如果查询比较要求返回包罗"abc"(abc 后没有空格)的所有行,则将返回以"abc"开始且具有零个或多个末端空格的所有行。

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作