当前位置:  数据库>sqlserver

sql通配符的使用方法

    来源: 互联网  发布时间:2014-08-29

    本文导语:  在sql server中使用sql通配符,有关详细信息,请参阅数据类型 (transact-sql)。like 关键字使用常规表达式包含值所要匹配的模式。 模式包含要搜索的字符串,字符串中可包含四种通配符的任意组合。   通配符 含义 % 包含零个...

在sql server中使用sql通配符,有关详细信息,请参阅数据类型 (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。如果转义符后面的字符不是通配符,则将放弃转义符并将该转义符后面的字符作为该模式中的常规字符处理。这包括百分号 (%)、下划线 (_) 和左括号 ([) 通配符(如果它们包含在双括号 ([ ]) 中)。

另外,在双括号字符 ([]) 内,可以使用转义符并将插入符号 (^)、连字符 () 和右括号 (]) 转义。


    
 
 

您可能感兴趣的文章:

  • sql通配符三个例子
  • SQL LIKE 语句中的通配符
  • sql模糊查询与sql通配符的用法
  • sql通配符用法参考
  • sql通配符语句用法简介
  • SQL Server通配符用法示例
  • sql 通配符用法实例教程
  • sql server排序之通配符过滤与数据分组
  • sql 通配符实例分享
  • SQL LIKE 通配符用法分享
  • C#使用带like的sql语句时防sql注入的方法
  • SQL高级应用之使用SQL查询Excel表格数据的方法
  • sql中varchar和nvarchar的区别与使用方法
  • Discuz批量替换帖子内容的方法(使用SQL更新数据库)
  • 在linux中导入sql文件的方法分享(使用命令行转移mysql数据库)
  • SQL Server中使用Linkserver连接Oracle的方法
  • 使用T-SQL的Split拆分字符串的方法
  • 在SQL Server中使用命令调用SSIS包的具体方法
  • 使用SQL Server数据库嵌套子查询的方法
  • sql server 还原数据库时提示数据库正在使用,无法进行操作的解决方法
  • sql server 在32位机器上使用AWE访问4GB以上内存的方法
  • 使用sql语句分离和附加数据库的方法
  • sql集合运算符使用方法
  • 使用sql语句在指定字段前面插入新的字段的方法
  • sql表连接查询使用方法(sql多表连接查询)
  • sql 中 case when 语法使用方法
  • 如何使用java连接到sql server数据库?任何方法均可!
  • SQL Server遍历表中记录的2种方法(使用表变量和游标)
  • sql server中使用Split()的方法介绍
  • 在SQL查询中使用LIKE来代替IN查询的方法
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • java命名空间java.sql接口statement的类成员方法: executeupdate定义及介绍
  • 安装SQL2008时提示删除SQL2005Express工具的解决方法
  • java命名空间java.sql接口connection的类成员方法: nativesql定义及介绍
  • sql无效字符引起的执行sql语句报错的解决方法
  • java命名空间java.sql接口preparedstatement的类成员方法: executeupdate定义及介绍
  • SQL Server降权运行 SQL Server 2000以GUESTS权限运行设置方法
  • java命名空间java.sql接口rowid的类成员方法: getbytes定义及介绍
  • (X86/X64)安装sql server 2005 过程中提示“无法启动sql server的 启动”的解决方法
  • java命名空间java.sql接口ref的类成员方法: getbasetypename定义及介绍
  • sql数据库多用户模式修改方法
  • java命名空间java.sql接口databasemetadata的类成员方法: getsqlkeywords定义及介绍
  • 安装sql server 2008 management提示已安装 SQL Server 2005 Express的解决方法
  • java命名空间java.sql接口rowid的类成员方法: tostring定义及介绍
  • C#代码验证sql语句是否正确(只验证不执行sql)的方法
  • java命名空间javax.sql.rowset接口joinrowset的类成员方法: getwhereclause定义及介绍
  • Sql2000与Sql2005共存安装的解决方法
  • java命名空间java.sql接口statement的类成员方法: execute定义及介绍
  • SQL查找某一条记录的方法
  • java命名空间java.sql接口resultset的类成员方法: getcursorname定义及介绍
  • sql server 代理(已禁用代理xp)的解决方法
  • java命名空间java.sql接口resultsetmetadata的类成员方法: getcolumntype定义及介绍
  • 更改sql server拥有者的方法
  • java命名空间javax.sql.rowset.spi类syncprovider的类成员方法: getrowsetwriter定义及介绍
  • 请问,这是什么错误!java.sql.SQLException: [Microsoft][ODBC SQL Server Driver][Named Pipes]??????? SQL Server?虽然分少,但一定给,只要您是前5名回复者中最好的以为!
  • java命名空间java.sql接口sqlinput的类成员方法: readblob定义及介绍
  • SQL查询分析工具 SQL Workbench/J
  • java命名空间java.sql接口sqlinput的类成员方法: readarray定义及介绍
  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)
  • java命名空间java.sql接口sqlinput的类成员方法: readsqlxml定义及介绍
  • 浙ICP备11055608号-3 iis7站长之家
  • java命名空间java.sql接口sqlinput的类成员方法: readrowid定义及介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3