第6课 用通配符进行过滤

6.1 LIKE 操作符

  前面介绍的所有操作符都是针对已知值进行过滤。但是,这种过滤方法并不是任何时候都好用。

  例如:怎样搜索产品名中包含文本 bean bag 的所有产品?

  【注意】通配符搜索只能用于文本字段(字符串),非文本数据类型字段不能使用通配符搜索

  【解析】通配符:用来匹配值的一部分的特殊字符

6.1.1 百分号(%)通配符

  %:任何字符出现任意次数

  例1:找出所有以词 Fish 起头的产品

SELECT prod_id, prod_name
FROM Products
WHERE prod_name LIKE 'Fish%';

  例2:可以使用多个通配符

  搜索包含文本 bean bag 的值

SELECT prod_id, prod_name
FROM Products
WHERE prod_name LIKE '%bean bag%';

  例3:找出以 F 起头、以 y 结尾的所有产品?

SELECT prod_name
FROM Products
WHERE prod_name LIKE 'F%y';

  【提示】根据部分信息搜索电子邮件

    有一种情况下把通配符放在搜索模式中间是很有用的,就是根据邮件的一部分来查找电子邮件,例如:

    WHERE email LIKE 'b%@qq.com'

  【注意】除了能匹配一个或多个字符外,%还能匹配0个字符。(0,1或多个字符)

  【注意】如果产品后面有一堆空格,'F%y'应改成'F%y%';或者用函数去掉空格

  【注意】WHERE prod_name LIKE '%' 不会匹配 NULL 的行

6.1.2 下划线(_)通配符

   _:只匹配单个任意字符

   例4:

SELECT prod_id, prod_name
FROM Products
WHERE prod_name LIKE '__ inch teddy bear';
-- 分析:LIKE 后面跟有文本的两个通配符

   结果:2个

   例5:观察使用 % 和 _ 的不同

SELECT prod_id, prod_name
FROM Products
WHERE prod_name LIKE '% inch teddy bear';

6.1.3 方括号([])通配符

  []:用来匹配一个字符集,它必须匹配指定位置(通配符的位置)中的一个字符

  例6:找出所有名字以 J 或 M 起头的联系人

SELECT cust_contact
FROM Customers
WHERE cust_contact LIKE '[JM]%';
-- 分析:[JM] 匹配方括号中任意一个字符,它也只能匹配单个字符。[JM]之后的 % 通配符匹配第一个字符之后的所有字符

  

  例7:查询匹配非 J 或 M 字符开头的任意联系人名

SELECT cust_contact
FROM Customers
WHERE cust_contact LIKE '[^JM]%';
-- 分析:通过前缀字符 ^(脱字号)来否定

  方法二:使用 NOT

  例8:

SELECT cust_contact
FROM Customers
WHERE NOT cust_contact LIKE '[JM]%';

6.2 使用通配符的技巧

  【性能】通配符搜索一般比前面讨论的其它搜索要耗费更长时间。

  【技巧】

    1.不要过度使用通配符。如果其它操作符能达到相同目的,应该使用其它操作符

    2.尽量不要讲它们用在搜索模式的开始处。把通配符置于开始处,搜索起来是最慢的。

    3.仔细注意通配符的位置

6.3 小结

  通配符的含义、使用及技巧

续集:

  SQLServer:《SQL必知必会》一书的读书笔记(五)

T-SQL:毕业生出门需知系列(六)的更多相关文章

  1. T-SQL:毕业生出门需知系列(七)

    第7课 创建计算字段 7.1 计算字段(格式化字段) 存储在数据库表中的数据一般不是应用程序所需要的格式,如: 1.需要显示公司名,同时还需要显示公司的地址,但这两个信息存储在不同的表列中. 2.列数 ...

  2. T-SQL:毕业生出门需知系列(五)

    第5课 高级数据过滤 5.1 组合 WHERE 子句 第4课介绍的 WHERE 子句在过滤数据时都是用单一的条件. 5.1.1 AND 操作符 检索由供应商 DLL01 制造且价格小于等于 4 美元的 ...

  3. T-SQL:毕业生出门需知系列(四)

    第4课 过滤数据 4.1 使用 WHERE 子句:过滤 只检索所需数据需要指定搜索条件(即过滤条件). WHERE 子句在表名(FROM 子句)后给出,根据 WHERE 子句中指定的条件过滤. SEL ...

  4. T-SQL:毕业生出门需知系列(二)

    第2课 检索数据 2.1 SELECT 语句 用途:从一个或多个表中检索数据信息 关键字:作为SQL组成部分的保留字.关键字不能用作表或列的名字. 为了使用SELECT检索表数据,必须至少给出两条信息 ...

  5. T-SQL:毕业生出门需知系列(目录)

    一.前言: 作为一个应届毕业生又要准备面试 ASP.NET 攻城狮了,以前在图书馆觉得这本书讲得挺基础,这次回家就自己买了本用来复习,顺便做下读书笔记. 第4版 二.代码下载: 官方:http://f ...

  6. T-SQL:毕业生出门需知系列(九)

    <SQL 必知必会>读书笔记 -- 第9课 汇总数据 9.1 聚集函数:对某些行运行的函数,计算并返回一个值 案例: -- 确定表中函数 -- 获得表中某些行的和 -- 找出表列的最大值. ...

  7. T-SQL:毕业生出门需知系列(八)

    第8课 使用函数处理数据 8.1 函数 [名词]可移植:所编写的代码可以在多个系统上运行 8.2 使用函数 8.2.1 文本处理函数 例1:使用 UPPER() 函数--将文本转换为大写 SELECT ...

  8. T-SQL:毕业生出门需知系列(三)

    第3课 排序检索数据 3.1 排序数据(ORDER BY) 下面的 SQL 语句返回某个数据库表的单个列.观察其输出,并没有特定的顺序. SELECT prod_name FROM Products; ...

  9. SQL Server 2008空间数据应用系列六:基于SQLCRL的空间数据可编程性

    原文:SQL Server 2008空间数据应用系列六:基于SQLCRL的空间数据可编程性 友情提示,您阅读本篇博文的先决条件如下: 1.本文示例基于Microsoft SQL Server 2008 ...

随机推荐

  1. grep 信息提取

    1.提取svn版本库的版本号 svn info |grep -Po '(?<=Revision: )[0-9]*'

  2. iOS tableview自定义cell上添加按钮实现删除功能

    在删除的时候,先删除数据源,再删除cell 但是,会发现一直崩: numberOfRowsInSection 解决方案:

  3. SQL 查找重复项及批量修改数据成固定格式

    1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断select * from peoplewhere peopleId in (select   peopleId  from ...

  4. Cocopod

    装了好几天,这个是比较全面的,大家可以看看帮助一下 1.新建一个项目,名称:CPTest 2.打开终端,输入"cd"+空格,然后将文件夹拖入到后面 3.回车后继续输入vim Pod ...

  5. css中单位px、pt、em和rem的区别

    国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢? px :像素(Pixel).相对长度单位.像素px是相对于显示器屏幕分辨率而言的.(引自CSS ...

  6. Convert PLY to VTK Using PCL 1.6.0 使用PCL库将PLY格式转为VTK格式

    PLY格式是比较流行的保存点云Point Cloud的格式,可以用MeshLab等软件打开,而VTK是医学图像处理中比较常用的格式,可以使用VTK库和ITK库进行更加复杂的运算处理.我们可以使用Par ...

  7. 对Java中正则表达式的一些理解

    2016-12-11 22:26:18 正则表达式的意义:正则表达式是一个字符串处理工具,可以对字符串进行查找/提取/分割/替换等等,也可以对用户输入的内容进行匹配. 常用的预定义字符就不解释了,网上 ...

  8. MYSQL删除重复数据

     delete from co_jobinformation cwhere c.name in (select cc.name from co_jobinformation cc group by   ...

  9. bgp多线

    BGP(边界网关协议)主要用于互联网AS(自治系统)之间的互联,BGP的最主要功能在于控制路由的传播和选择最好的路由. 中国网通 .中国电信.中国铁通.教育网和一些大的民营IDC运营商都具有AS号,全 ...

  10. Jenkins常用插件说明(持续更新)

    本文主要记录在学习以及使用Jenkins过程中常用的对我们有帮助的插件,同时本文将会持续进行更新.如果大家发现有其他野很好用的插件,也欢迎参照下面的格式,在评论中进行回复反馈. 一.通用插件 1.Em ...