首页 优化推广 SQL提高查询效率之Like篇

SQL提高查询效率之Like篇

来源: | 时间:2011/4/15 15:52:43 |

   在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 是否都在电话簿上,都应知道该从何处开始查找。

TAG:高端网站建设高端网站设计网站制作网站建设

服务热线

153 8323 9821

功能和特性

价格和优惠

网站和维护

推广和优化

微信服务号