ANY ALL SOME的区别

干了这么长时间的ORACLE,但是真正用到ANY ALL还有SOME的并不多,而且还真的不知道有SOME这个东西,这次补一下知识

首先看一下官方文档中给的解释




SOME ANY

Compares a value to each value in a list or returned by a query. Must be preceded by =, !=, >, <, <=, >=. Can be followed by any expression or subquery that returns one or more values.

Evaluates to FALSE if the query returns no rows.

SELECT * FROM employees
  WHERE salary = ANY
  (SELECT salary 
   FROM employees
  WHERE department_id = 30)
  ORDER BY employee_id;

ALL

Compares a value to every value in a list or returned by a query. Must be preceded by =, !=, >, <, <=, >=. Can be followed by any expression or subquery that returns one or more values.

Evaluates to TRUE if the query returns no rows.

SELECT * FROM employees
  WHERE salary >=
  ALL (1400, 3000)
  ORDER BY employee_id;

看来SOME和ANY是一回事, ANY和ALL的区别看起来是2点

1).each value 和 every value,
从中文意思来说都是每个值,其实这个就是翻译带来的问题了,其实ANY和SOME在each value应该翻译成任意一个值 ,但是every value 对于ALL来说是应该翻译成所有值, 这下就清楚了,对于ANY和SOME是比较列表或者子查询的任意一个值,只要有满足条件即可,和OR效果一样.但是对于ALL来说,需要比较列表和子查询的所有值AND的想过一样                                                                                                                      

2).如果子查询为空的时候返回结果是不同的
当使用ANY或者SOME的时候,如果后面的子查询是空,则整个表达式返回结果是FALSE,也就一位置SELECT可能返回的结果就是空值,这个需要注意。但是如果返是ALL的话,当子查询是空的时候返回时TURE,可能不会影响色了SELECT的整体结果                                                                                                                                                                                                                                                                                                                   
链接来自:        
http://docs.oracle.com/database/121/SQLRF/conditions002.htm#SQLRF52107
                                                                                                                                                

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/8747612/viewspace-1873758/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/8747612/viewspace-1873758/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值