MySQL数据库:数据过滤

组合WHERE子句

WHERE子句在过滤数据时使用的都是单一的条件。为了进行更强的过滤控制, MySQL允许给出多个WHERE子句。这些子句可以两种方式使用:以AND子句的方式或OR子句的方式使用。
操作符(operator) 用来联结或改变WHERE子句中的子句的关键字。也称为逻辑操作符( logical operator) 。
AND操作符
为了通过不止一个列进行过滤,可使用AND操作符给WHERE子句附加条件。
  • SELECT vend_id,prod_price FROM products WHERE vend_id = ‘DLL01’ AND prod_price = 3.49;

在这里插入图片描述

OR操作符

OR操作符与AND操作符不同,它指示MySQL检索匹配任一条件的行.
分析:此SQL语句检索由任一个指定供应商制造的所有产品的产品名和价格。 OR操作符告诉DBMS匹配任一条件而不是同时匹配两个条件。如果这里使用的是AND操作符,则没有数据返回(此时创建

的WHERE子句不会检索到匹配的产品)。

  • SELECT vend_id FROM products WHERE vend_id = ‘DLL01’ OR vend_id =‘BRS01’;

在这里插入图片描述

  • SELECT vend_id FROM products WHERE vend_id = ‘DLL01’ AND vend_id =‘BRS01’;

在这里插入图片描述

计算次序

WHERE可包含任意数目的AND和OR操作符。允许两者结合以进行复杂和高级的过滤。
需要列出价格为3.49美元(含)以上且由1002或1003制造的所有产品。下面的SELECT语句使用AND和OR操作符的组合建立了一个WHERE子句:
原因在于计算的次序。 SQL(像多数语言一样)在处理OR操作符前,优先处理AND操作符。当SQL看到上述WHERE子句时,它理解为由供应商DLL01制造的任何价格为5.99美元(含)以上的产品,或者由供应商BRS01制造的任何产品,而不管其价格如何。换句话说,由于AND在计算次序中优先级更高,操作符被错误地组合了
错误实例
  • SELECT vend_id,prod_name,prod_price FROM products WHERE vend_id = ‘DLL01’ OR vend_id =‘BRS01’ AND prod_price >= 5.99;

在这里插入图片描述

解决方法是使用圆括号明确地分组相应的操作符

前两个条件用圆括号括了起来。因为圆括号具有较AND或OR操作符高的计算次序, DBMS首先过滤圆括号内的OR条件。这时, SQL语句变成了选择由供应商DLL01或BRS01制造的且价格都在5.99美元(含)以上的任何产品
  • SELECT vend_id,prod_name,prod_price FROM products WHERE (vend_id = ‘DLL01’ OR vend_id =‘BRS01’) AND prod_price >= 5.99;

在这里插入图片描述

注意:在WHERE子句中使用圆括号 任何时候使用具有AND和OR操作符的WHERE子句,都应该使用圆括号明确地分组操作符。不要过分依赖默认计算次序,即使它确实是你想要的东西也是如此。使用圆括号没有什么坏处,它能消除歧义。

IN操作符

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

在这里插入图片描述

注意:IN和OR的左右差不多
优点:
1在使用长的合法选项清单时, IN操作符的语法更清楚且更直观。
2 在使用IN时,计算的次序更容易管理(因为使用的操作符更少)。
3 IN操作符一般比OR操作符清单执行更快。
4 IN的最大优点是可以包含其他SELECT语句,使得能够更动态地建
立WHERE子句。

NOT操作符

WHERE子句中的NOT操作符有且只有一个功能,那就是否定它之后所跟的任何条件。
MySQL不是匹配DLL01和 BRS01的 vend_id , 而 是 匹 配DLL01和 BRS01之 外 供 应 商 的vend_id。
  • SELECT vend_id,prod_name,prod_price FROM products WHERE vend_id NOT in (‘DLL01’,‘BRS01’) ORDER BY prod_name;

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值