mysql学习笔记-where高级查询

AND

语句:SELECT prod_id, prod_price, prod_name FROM Products WHERE vend_id = ‘DLL01’ AND prod_price <= 4;

输出结果:
prod_id prod_price prod_name


BNBG02 3.4900 Bird bean bag toy
BNBG01 3.4900 Fish bean bag toy
BNBG03 3.4900 Rabbit bean bag toy

要对不止一个列进行过滤,可以使用AND操作符给WHERE子句附加条件,上述语句中设置了两个过滤条件,AND操作符的限制下只返回同时满足所有给定条件的行。如果需要同时满足多个条件,只需要在每个条件间都加一个AND。

OR

语句:SELECT prod_name, prod_price FROM Products WHERE vend_id = ‘DLL01’ OR vend_id = ‘BRS01’;

输出结果:
只要列的值符合任意一个过滤条件,就会被返回。

OR关键字用匹配查询任一给定条件的值的所在行。

AND和OR的优先级

语句:SELECT prod_name, prod_price FROM Products WHERE (vend_id = ‘DLL01’ OR vend_id = ‘BRS01’) AND prod_price >= 10;

输出结果:列出价格为10美元及以上,且由DLL01或BRS01制造的所有产品。

这条语句中,可以看到前两个条件用圆括号括了起来。因为圆括号具有比AND或OR操作符更高的求值顺序,所以语句首先过滤圆括号内的OR条件。这时,SQL语句变成了选择由供应商DLL01或BRS01制造的且价格在10美元及以上的所有产品。
如果不加括号的话,后面的AND前后两个条件会被组合并且优先执行,这条语句会被理解为:由供应商BRS01制造的价格为10美元以上的所有产品,以及由供应商DLL01制造的所有产品,不管加个是多少。

注意:任何时候使用具有AND和OR的WHERE子句,都应该使用圆括号明确地对过滤条件进行分组。

IN操作符

语句:SELECT prod_name, prod_price FROM Products WHERE vend_id IN ( ‘DLL01’, ‘BRS01’ ) ORDER BY prod_name;

输出结果:只要列的值符合IN里面的任意一个过滤条件值,就会被返回。

IN操作符用来指定条件范围,范围中的每个条件都可以进行匹配,各个条件值的关系和OR操作符是一样的。IN后面跟的是一组由逗号分隔、括在圆括号中的合法值。

使用IN操作符的优点:

  • 在有很多合法选项时,IN操作符的语法更清楚,更直观。
  • 在与其他AND和OR操作符组合使用IN时,过滤条件更容易管理。
  • IN操作符一般比一组OR操作符执行得更快(在上面这个合法选项很少的例子中,你看不出性能差异)。
  • IN的最大优点是可以包含其他SELECT语句,能够更动态地建立WHERE子句。(这一条后面会学到)

NOT操作符

语句:SELECT prod_name FROM Products WHERE NOT vend_id = ‘DLL01’ ORDER BY prod_name;

输出结果:
列出了除供应商DLL01之外的其他所有供应商制造的产品

WHERE子句的NOT操作符,用在要过滤的列前,否定NOT后面跟的条件,NOT经常是和其他操作符一起使用。

注意:这里要考虑操作符的优先级,如果是这样的语句:SELECT * FROM tr_email_job_hh WHERE NOT error_type = 1 OR error_type = 21,这个语句取的是error_type 不等于1的结果和error_type等于21的结果的并集,如果是这样的语句:SELECT * FROM tr_email_job_hh WHERE NOT (error_type = 1 OR error_type = 21),取的就是error_type 不等于1的结果和error_type不等于21的所有的结果的并集。所以NOT只是针对后面跟的第一个条件有效,
在复杂的子句中,NOT是非常有用的。例如,在与IN操作
符联合使用时,NOT可以非常简单地找出与条件列表不匹配的行。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值