SQL提高查询效率之Like篇
发布时间:2011-10-01 09:36:42
在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"开始且具有零个或多个末尾空格的所有行。


猜你喜欢
- 在app挂载的div同级处写一个加载动画,例如:<body class="font-hei">
- 1.用phpmyadmin创建数据库和数据表 创建数据库的时候,请将“整理”设置为:“utf8_general_ci” 或执行语句:CREA
- 如下所示: out = subprocess.getstatusoutput('adb shell pm
- 做网站数据库,是选SQL Server还是Access好,可能您会说:选MySQL好,不过现在只是讨论IIS+ASP这种架构下的选择,不讨论
- 设置自动的参数注释标识如何使用pycharm自动添加引用注释描述功能使用场景多行注释,且需要对传入的参数以及返回值进行详尽的阐述时,如下图设
- 直接利用numpy读取非数字型的数据集时需要先进行转换,而且python3在处理中文数据方面确实比较蛋疼。最近在学习周志华老师的那本西瓜书,
- 目录前言魔法方法__init__方法__new__方法__call__方法__str___方法__del___方法__enter__ &am
- 在上篇博客中,提到了对一个脚本进行的多次优化。当时以为已经优化得差不多了,但是当测试人员测试时,我才发现,踩到了Python的一个大坑。在上
- 本文实例为大家分享了python将图片转成字符画的具体代码,供大家参考,具体内容如下该代码引用了PIL库的Image,所以必须先安装PIP,
- 本文实例讲述了Python双链表原理与实现方法。分享给大家供大家参考,具体如下:Python实现双链表文章目录Python实现双链表定义链表
- 本文主要介绍了python图片转为矢量图,分享给大家,具体如下:import numpy as npimport matplotlib.py
- ''推拉门''动效也可以称作"手风琴"效果,大多数效果实现的思路基本是一样的,下面介绍两
- 如下所示:# 导入模块import win32guiwin = win32gui.FindWindow(None, u'张三'
- 现在,我们已经把一个Web App的框架完全搭建好了,从后端的API到前端的MVVM,流程已经跑通了。在继续工作前,注意到每次修改Pytho
- 我们经常会发现网页中的许多数据并不是写死在HTML中的,而是通过js动态载入的。所以也就引出了什么是动态数据的概念,动态数据在这里指的是网页
- 在用pyinstaller打包后不想要后面的终端命令框,但是打包时加了-w或者--noconsole命令后会导致cmd程序不能运行从而出错。
- 本文实例讲述了python版本的读写锁操作方法。分享给大家供大家参考,具体如下:最近要用到读写锁的机制,但是python2.7的自带库里居然
- 早上我偶然看见一篇介绍两个Python脚本的博文,其中一个效率更高。这篇博文已经被删除,所以我没办法给出文章链接,但脚本基本可以归结如下:f
- 之前也写过这个小组件,最近遇到select下加搜索的功能,所以稍微完善一下。效果图:子组件 dropdown.vue<template
- PyQt5访问系统剪切板QClipboard类介绍QClipboard类提供了对系统剪切板的访问,可以在应用程序之间复制和粘贴数据,它的操作