《SQL必知必会》笔记(MySQL实现)---通配符的使用

本文主要讲的是SQL中通配符的相关知识和使用方法。

之前介绍的所有的数据过滤操作都是针对已知值进行�的。但是,这种过滤方法不是任何时候都好用。比如当需要搜索产品名中包含文本“Hello”的所有产品,用简单的比较操作符肯定没法做到,这时就需要用到本文讲的通配符。� 通配符 是用来匹配值的一部分的特殊字符,利用通配符,可以创建比较特定数据的搜索模式。关于搜索模式需要解释一下, 搜索模式 指的是由字面值、通配符或两者组合构成的�搜索条件。

通配符本身实际上是SQL的WHERE子句中有特殊含义的字符,SQL支持几种通配符。在句子中使用通配符的时候,需要配合LIKE操作符。LIKE操作符指示DBMS,后跟的搜索模式是利用通配符匹配而不是简单的相等匹配进行比较。

�严格意义上来说,LIKE是 谓词 而不是操作符。这种说法有点像我们学语文的时候分析句子的结构里的”谓语“,所以,LIKE也不能单独使用。还有一点需要注意的是,通配符搜索只能用于文本字段(字符串),非文本字段不能使用通配符搜索。

MySQL支持百分号(%)和下划线(_)这两种通配符,下面来看看这两种通配符的用法和区别。

百分号( % )通配符

在一般的使用中,百分号( % )通配符是最常用的。在搜索串中,% 表示任何字符出现任意次数。下面来看下如何使用,现在要找出所有以“Fish”起头的产品:

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

结果如下:

百分号通配符-1.png

可以看到,这条语句检索了任意以"Fish"起头的�产品名称,并且 % 匹配的是任意字符,不管有多少个。

根据DBMS的不同以及其配置,搜索可以是区分大小写的,如果是区分大小写的话,上面的查询语句就不会返回值了。MySQL是不区分大小写的。

通配符可以在搜索模式�中的任意位置使用,并且可以使用多个通配符。下面的例子来看一下使用两个通配符的情况:

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

结果如下:

百分号通配符-2.png

这条语句会搜索任何位置上包含文本'bean bag'的值,不论它之前或者之后出现什么字符。

在日常的使用中,通过通配符来匹配Email地址是一个非常有效的方法,比如 WHERE email LIKE 'a%@example.com'

需要特别注意的是,% 不仅可以匹配1个或者多个字符,还可以匹配0个字符。还有一点就是,% 号无法匹配 NULL,就像之前说过的一样,DBMS不知道NULL将会代表什么。

下划线( _ )通配符

另一个需要介绍的是下划线 _ 通配符。_ 的用法和 % 一样�,区别在于它只匹配单个字符。

�先看下面这个例子:

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

结果如下:

下划线通配符-1.png

这个SQL语句检索出了开头�是两个字符的prod_name,�需要注意的地方就是需要匹配多少个字符就用多少个下划线。可以使用 % 通配符对照一下效果:

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

结果如下:

下划线通配符-2.png

这个结果可以充分的说明� _ 和 % 的区别。

以上简单的介绍了一下这两种通配符的用法和区别。

SQL的通配符使用起来很方便,功能也很强大,但是代价就是通配符搜索一般来说会比之前介绍过的搜索耗费更长的时间。所以有一些通配符的使用技巧需要了解:

  • 不要刻意的使用通配符。如果其他操作符能达到相同目的,应该使用其它操作符。
  • 当必须使用通配符时,尽量不要把它们放在搜索模式开始的地方,因为把通配符放在开始的地方,搜索的效率是最慢的。
  • 最后需要注意的,也是最重要的,就是一定要注意通配符的位置和数量,因为一旦出了什么问题,返回的结果可能和预期会有很大的出入。

以上就是本文的所有内容,下一篇文章将会介绍SQL中有关计算字段的知识。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容