MySQL 搜索语句--过滤数据

MySQL使用SELECT语句的WHERE子句指定搜索条件。

使用WHERE子句

数据库表一般包含大量的数据,有时我们可能只需要检索表中的一部分数据,只检索所需数据需要指定搜索条件(search criteria),搜索条件也称为过滤条件(filter condition)。

WHERE 子句在表名(FROM子句)之后给出。

SELECT name, price
FROM products
WHERE price = 2.50;

这条语句从products表中检索两个列,但是是不返回所有行,只返回price值为2.50的行。如下所示:

+---------+-----------+
|  name   |    price  |
+---------+-----------+
| Carrots |    2.50   |
| TNT     |    2.50   |
+---------+-----------+

$在同时使用ORDER BY和WHERE 子句时,应该让ORDER BY位于WHERE 之后,否则会产生错误$

WHERE子句操作符

--------------------------------------------
    操作符                说明
--------------------------------------------
      =                   等于
      <>                  不等于
      !=                  不等于
      <                   小于
      <=                  小于等于
      >                   大于
      >=                  大于等于
      BETWEEN             在指定的两个值之间
----------------------------------------------

检查单个值

SELECT name, price 
FROM products
WHERE name='fuses';

输出如下:

+---------+-----------+
|  name   |    price  |
+---------+-----------+
| Fuses   |    3.42   |
+---------+-----------+

检查WHERE name='fuses'语句,它返回name的值为Fuses的一行,MySQL在执行匹配时不区分大小写,所以fuses与Fuses匹配

不匹配检查

以下例子列出不是由供应商1003制造的所有产品

SELECT id, name 
FROM products
WHERE id <> 1003;

输出如下:

+---------+-----------+
|  id     |    name   |
+---------+-----------+
| 1001    |    Fuses1 |
| 1002    |    Fuses2 |
| 1004    |    Fuses4 |
| 1005    |    Fuses5 |
+---------+-----------+

PS:在使用WHERE子句时,单引号用来限定字符串。如果将值与串类型的列进行比较,则需要限定引号;如果与数值列进行比较的值不用引号
以下语句和上面的例子相同

SELECT id, name 
FROM products
WHERE id != 1003;

范围值检查

为了检查某个范围的值,可以使用BETWEEN操作符。
下面的例子说明如何使用BETWEEN操作符,它检索价格在5美元和10美元之间的所有产品。

SELECT name, price 
FROM products
WHERE price BETWEEN 5 AND 10;

结果如下所示:

+---------+-----------+
|  name   |    price  |
+---------+-----------+
| Fuses1  |    5.42   |
| Fuses4  |    6.12   |
| Fuses3  |    7.92   |
| Fuses2  |    9.42   |
+---------+-----------+

PS:在使用BETWEEN时,必须指定两个值,这两个值必须用AND关键字分隔。

空值检查

NULL 无值(no value),他与字段包含0,空字符串或仅仅包含空格不同。
SELECT语句有一个特殊的WHERE子句 IS NULL,它用来检查具有NULL值得列

SELECT name
FROM products
WHERE price IS NULL;

这条语句返回没有价格(空price字段,不是价格为0)的所有产品,由于表中没有这样的行所以没有返回行

NULL 与不匹配 在通过过滤选择出不具有特定值得行时,你可能希望返回具有NULL值的行。但是,不行。因为位置具有特殊的含义,数据库不知道他们是否匹配所以在匹配过滤或不匹配过滤时不返回它们;
因此,过滤数据时,一定要验证返回数据中确实给出了被过滤列具有NULL的行。

数据过滤

组合WHERE子句

AND
为了进行更强的过滤控制,MySQL允许给出多个WHERE子句,这些子句可以两种方式使用:以AND子句的方式或OR子句的方式使用。

SELECT id, price, name
FROM products 
WHERE id=1003 AND price<=10;

此SQL语句检索由供应商1003制造且价格小于等于10美元的所有产品的名称和价格
ADN 用在WHERE子句中的关键字,用来指示检索满足所有给定条件的行。

OR

SELECT id, price, name
FROM products 
WHERE id=1003 OR id=1002;

次SQL语句检索由任一指定供应商创造的所有产品的产品的名字和价格。
OR WHERE 子句中使用的关键字,用来表示检索匹配任一给定条件的行。

计算次序

WHERE 可以包含任意数目的AND和OR操作符。允许两者结合以进行复杂和高级的过滤。
但是由于AND和OR的优先级不同,AND的优先级要高于OR的优先级,所以在同时使用AND和OR时,要给OR加括号
例如:

SELECT id, price, name
FROM products 
WHERE (id=1003 OR id=1002) AND price >= 10;

IN 操作符

圆括号在WHERE子句中还有另一种用法。IN操作符用来指定条件范围,范围内的每个条件都可以进行匹配。IN取合法值的由逗号分隔的清单,全部都在圆括号中。

SELECT id, price, name
FROM products 
WHERE id IN (1002, 1003)
ORDER BY name;

次语句检索供应商1002和1003创造的所有产品。
IN操作符后跟由逗号分隔的合法值清单,整个清单必须括在圆括号中。
IN 操作符的优点:

  • 在使用长的合法选项清单时,IN操作符的语法更清楚且直观。
  • 在使用IN时,计算的次序更容易管理(因为使用的操作符更少)
  • IN操作符一般比OR操作符清单执行更快
  • IN的最大优点是可以包含其他SELECT语句,使得能够更动态的建立WHERE子句。
    IN WHERE子句中用来指定要匹配的清单的关键字,功能与OR相当。

NOT 操作符

NOT WHERE 子句中用来否定后跟条件的关键字。
下面的例子,列出除了1002和1003之外的所有供应商制造的产品。

SELECT id, price, name
FROM products 
WHERE id NOT IN (1002, 1003)
ORDER BY name;

LIKE 操作符

百分号(%)通配符

最常使用的通配符是百分号(%),在搜索串中,%表示任何字符出现任意次数。例如,为了找出所有以词jet起头的产品,可以使用SELECT语句:

SELECT id, name
FROM products
WHERE name LIKE 'jet%';

通配符可以在搜索模式中任一位置使用,并且可以使用多个通配符。

SELECT id, name
FROM products
WHERE name LIKE '%anvil%';

搜索模式‘%anvil%’表示匹配任何位置包含文本anvil的值,而不论它之前或者之后出现什么字符

重要的是要注意到,除了一个或多个字符外,%还能匹配0个字符。%代表搜索模式中给定位置的0个,1个,或者多个字符。
注意尾空格 尾空格可能会干扰通配符。例如,在保存词anvil时,如果它后面有一个或多个空格,则子句WHERE name LIKE '%anvil'将不会匹配他们,因为在最后的l后面有多余的字符。解决这个问题的一个简单办法是在搜索模式最后附加一个%或者使用函数
%不能匹配NULL

下划线(_)通配符

下划线的用途与%一样,但是下划线只匹配单个字符而不是多个字符。

SELECT id, name
FROM products
WHERE name LIKE '_ ton anvil';

显示效果如下:

+---------+-----------------+
|  id     |    name         |
+---------+-----------------+
| 1001    |    .5 ton anvil |
| 1002    |     1 ton anvil |
| 1004    |     2 ton anvil |
+---------+-----------------+

与%能匹配0个字符不一样,_总是匹配一个字符,不能多也不能少

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

推荐阅读更多精彩内容