MySQL知识学习——第七天:数据过滤

前言

我们昨天学习了,where语句的基本用法,但是我们发现它只有过滤一个条件,那么有多个条件应该怎么办呢?

今天我们就来进一步学习数据过滤

AND 操作符

我们昨天在介绍BEWTEEN的时候提到了AND,那么今天将进一步了解它的用法。
首先解释一下什么是操作符

操作符(operator):用来联结或改变WHERE子句中的子句的关键
字。也称为逻辑操作符( logical operator)

也就是说操作符是特指在where子句中联接或改变子句的关键字,也就是说操作符是一种特殊的关键字,所以有时候我们会说关键字AND,也会说操作符AND。

当我们有多个过滤条件是,可以用AND操作符进行分隔,它在逻辑上相当于“且”。其实也很好理解,我们在使用其他语言的时候也会用到and,核心是差不多的。比如我们看下面的例子

在这里插入图片描述
上面的例子有两个过滤条件,即筛选math和english都大于80的记录,必须同时满足这两条才可以被筛选出来。

同样的,我们也可以有三个筛选条件
在这里插入图片描述
其他更多的筛选条件的用法类似。

总结一下
AND是用在WHERE子句中的关键字,用来指示检索满足所有给定条件的行

OR操作符

or操作符逻辑上相当于或,也就是说满足其中一条过滤条件即可被筛选出来。
在这里插入图片描述

上面的例子中筛选的是满足math大于80或者English 大于80 的列,满足其中一条即可被筛选出来,如ID为3的记录,当然两条都满足也能被筛选出来,如ID为1的记录。

同样的,多个过滤条件也可以用OR,只要满足其中一条就可以被筛选出来
在这里插入图片描述

总结如下
OR是WHERE子句中使用的关键字,用来表示检索匹配任一给定条件的行。

计算次序

前面我们提到了AND和OR,在WHERE子句中可以包含任意数目的AND和OR操作符,也允许两者结合来进行复杂和高级的过滤。

既然我们混用它们两个,那么先计算那个呢?就好比我们学习的加减乘除,总有一个计算的先后顺序吧,我们先来看看下面的例子

在这里插入图片描述
根据结果来看,上面代码的含义是,筛选math大于80,或者English和Chinese均大于80的记录,也就是说,SQL先执行的and,后执行的or。

SQL(像多数语言一样)在处理OR操作符前,优先处理AND操作符。

为了使代码更容易阅读,我们通过圆括号来进行分组,SQL会优先执行圆括号内的内容(也就是说在SQL中圆括号的优先级比AND和OR高)。

在这里插入图片描述
添加括号后,就变成了筛选 math和English均大于80,或者Chinese 大于80的记录。(尽管结果是一样的,因为这个表中各条记录的设置不够好,感兴趣的话可以自己下去试试看)

任何时候使用具有AND和OR操作符的WHERE子句,都应该使用圆括号明确地分组操作符。不要过分依赖默认的计算次序。

IN操作符

IN操作符用来指定条件范围,范围中的每个条件都可以进行匹配。
在这里插入图片描述
注意IN后面跟一个类似于集合的字段,用来筛选值在该集合里面的记录,包含左右端点。 比如说上面的例子就是筛选math为79或者为80的记录。

为什么说是类似于集合的东西呢,看下面的例子
在这里插入图片描述
也就是说前面的数字可以大于后面的数字,结果不会有区别。注意如果表中有一条记录的math为80,也不会被筛选出来,因为那是一个集合,而不是一个区间,也就是说只会筛选math为79或者90的记录

在这里插入图片描述

上面的效果也可以通过OR操作符来实现,不妨试试。

既然介绍了OR,那么为啥还要介绍IN呢,当然是有意义的
在这里插入图片描述

总结
IN是WHERE子句中用来指定要匹配值的清单的关键字,功能与OR相当。

NOT操作符

对,这个其实也在其他语言中也会出现,表示否定。

WHERE子句中的NOT操作符有且只有一个功能,那就是否定它之后所跟的任何条件。

看下面的例子
在这里插入图片描述
上述的例子表示筛选math不是79和90的记录,注意不会筛选空值的记录(不论是否取反,都不会筛出空值记录,比如说我们的第六条记录)

在这里插入图片描述

晚安咯,祝大家六一快乐~

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值