网络编程
位置:首页>> 网络编程>> 数据库>> SQL提高查询效率之Like篇

SQL提高查询效率之Like篇

  发布时间:2011-10-01 09:36:42 

标签:sql,like,效率

 在SQL查询中,关键词Like可提供模糊查询功能,它通常与通配符一起使用。

1 Like条件适用数据库字段类型

    可与LIKE配对的数据类型有字符串、日期或时间值等。

2 通配符

  • %    包含零个或更多字符的任意字符串

  • _    任何单个字符

  • [ ]  指定范围(例如 [a-f])或集合(例如 [abcdef])内的任何单个字符

  • [^]  不在指定范围(例如 [^a - f])或集合(例如 [^abcdef])内的任何单个字符


使用时需将通配符和字符串一起用单引号引起来,例如:

    LIKE 赵%     将搜索姓赵的人名或者说以汉字‘赵’ 开头的字符串(如 赵刚、赵小刚等)。
    LIKE %刚     将搜索以汉字‘刚’结尾的所有字符串(如刘刚、李小刚等)。
    LIKE %小%    将搜索在任何位置包含汉字‘小’的所有字符串(如赵小刚、李小刚、山本小郎等)。
    LIKE _小刚   将搜索以汉字“小刚”结尾的所有三个汉字的名称(如 李小刚、赵小刚)。

针对英文,情形更多,如
    LIKE [CK]ars[eo]n 将搜索下列字符串:Carsen、Karsen、Carson 和 Karson(如 Carson)。
    LIKE [M-Z]inger    将搜索以字符串 inger 结尾、以从 M 到 Z 的任何单个字母开头的所有名称(如 Ringer)。
    LIKE M[^c]%        将搜索以字母 M 开头,并且第二个字母不是 c 的所有名称(如 MacFeather)。

3 Like条件的使用

    在author表中,查询所有区号为 010 的电话号码的SQL语句如下:

 


SELECT phone
FROM pubs.dbo.authors
WHERE phone LIKE 010%


    在 authors 表中查找区号不是 010 的所有电话号码,可使用以下SQL语句:

 


SELECT phone
FROM pubs.dbo.authors
WHERE phone NOT LIKE 010%




 


SELECT phone
FROM pubs.dbo.authors
WHERE NOT phone LIKE 010%


    查询从 authors 表中检索以 010 开头且 IS NOT NULL 的所有电话号码的SQL语句为:

 


USE pubs
SELECT phone
FROM authors
WHERE phone LIKE 010% and phone IS NOT NULL


    可用于 text 列的 WHERE 条件只有 LIKE、IS NULL 或 PATINDEX。
    不与 LIKE 一同使用的通配符将解释为常量而非模式,换言之,这些通配符仅代表其本身的值。下列查询试图查找到少由四个字符 010% 组成的电话号码。该查询并不会查找以 010 开头的电话号码。

 


SELECT phone
FROM pubs.dbo.authors
WHERE phone = 010%


3 Like的查询效率

    如果表达式以通配符开头,就不能使用索引。(就如同给定了姓名"%mith"而非"Smith"时,将无法知道应从电话簿的哪一页开始查找。)

    表达式中间或结尾处的通配符不妨碍使用索引,如同在电话簿中一样,如果姓名为"Samuel%",则不论 Samuels 和 Samuelson 是否都在电话簿上,都应知道该从何处开始查找。

3 Like的特殊情况

二、Like特殊情况:搜索通配符字符

    上面的搜索可以针对普通的汉字或中文,那如果遇到上述四种通配符要被搜到时应该如何处理呢?首先需注意的是通配符字符可以搜索,并且有两种方法可指定平常用作通配符的字符:

    使用 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"开始且具有零个或多个末尾空格的所有行。

0
投稿

猜你喜欢

  • 原来的题目设想为界面视觉效果的统一性,但是“统一”这个词似乎有点敏感,怕触动萌点无数,而我也无意去设定一个什么什么的统一性来侃侃而谈,极为专
  • 人常常感受到色彩对自己心理的影响,这些影响总是在不知不觉中发挥作用,左右我们的情绪。色彩的心理效应发生在不同层次中。有些属直接的刺激,有些要
  • 通过XSL转换XML文件 最近,我喜欢上了XML编程,但又苦于它的美观程度又不够,找了许多书才搞定。用XML好是蛮好,但它还是不太适合做显示
  • 问:如何给导入文件加上时间戳标记?答:请参考下文中介绍的两种方法:1.在DOS下从系统获得时间戳利用Dos命令取得时间戳:C:\>ec
  • 九宫格是一种比较古老的设计,它最基本的表现其实就像是一个三行三列的表格。其实它最初是在window的c/s结构中用得比较多,比如我们经常看到
  •  本文实例介绍了使用javascript来经验表单数据的方法,如:校验是否为英文,校验是否为数字及校验IP地址等: &l
  • 建立池连接可以显著提高应用程序的性能和可缩放性。SQL Server .NET Framework 数据提供程序自动为 ADO.NET 客户
  • 我们经常见到很多网站留言系统的显示访客的IP地址都是隐藏了一部分,以达到隐蔽访客真实地理位置的功能。如:111.222.333.*,当然在系
  • 无意中看到一位学员的屏保,感觉挺有意思的,就把它实现了下来效果如下:<!DOCTYPE html PUBLIC "-//W3
  • 分析社交网站,顺带画了张图,关于facebook的基本信息架构,没有涉及应用和插件的分析。 
  • 昨天在网上看到一个防采集软件,说采集只访问当前网页,不会访问网页的图片、JS等,今天突然想到,通过动态程序和Js访问分别记录访问者的IP,然
  • 本文由 kouyubo 整理到现在为止,只有一些已经工作的特性,他们中的一些如下:圆角从web2.0开始,开始流行使用圆角,如果你不使用圆角
  • 两行JavaScript代码的QQ窗口抖动效果<img  id="win" style='pos
  • 前言:话说,我一直没能理解美工究竟是什么(这是一篇投稿)。因为要求确实很多。目前,我只能理解成,是前端开发+页面设计+用户体验设计的全能手。
  • original article by sp(’Sergio Pereira’) Sergio Pereiralast update: Ma
  • RegExp对象的语义和使用:检查字符串匹配获取字符串中的部分内容在原字符串的基础上构建一个新的字符串(包括添加、删除和修改)构建一个Reg
  • 关于英文的写作有一本十分著名的书,The Elements of Style(风格要素),编写程序也有一本The Elements of P
  • 我和朋友都建了一个电子商务网站,大量的访问,频繁地建立和中断数据库连接,导致Web 数据库应用程序降低了数据库服务器的性能。但最近,朋友使用
  • <!--#include file="conn/conn.asp"--> <% set Newslis
  • 现状≠将来?程序员做设计本身就很悲哀,纠结于客户与坚持之间就更是如此。无论我今后的路会怎么走,我想始终不变的事情就是与客户博弈了。无论是放弃
手机版 网络编程 asp之家 www.aspxhome.com