ANY、ALL 和 SOME关键字的用法

前言

        SOME、ANY、ALL是一种逻辑运算符,作用是将子查询返回的单列值的集合与查询的单个值作比较。SOME、ANY、ALL前面需跟比较运算符(>,<,>=,<=,=,<>)。这里只有当子查询中的值为单值 或者与子查询中的值完全相等时,才可以使用 = 号,否则就不能使用 = 号。SOME 是 ANY的一个同义词,功能相同。

        在使用 ANY、ALL 时,前面必须跟比较运算符(>,<,>=,<=,=,<>),后面跟子查询语句。

一、ANY 关键字

        功能类似于逻辑原算符 或( or )。

select  *  from  table   where   a >  any( ... )

--  如果 any 后面跟的子查询返回的数据集中包含了 result1,result2,result3 三个值。

那么,上面的语句就可以看作:

select * from table  where a > result1 or a > result2 or a > result3;

--  即a大于子查询中的任意一个,等同于a大于子查询的最小值即可。

二、ALL 关键字

        功能类似于逻辑运算符 且( and )。

select  *  from  table   where   a >  all( ... )

--  如果 any 后面跟的子查询返回的数据集中包含了 result1,result2,result3 三个值。

那么,上面的语句就可以看作:

select * from table  where a > result1 and a > result2 and a > result3;

--  即a大于子查询中的每一个,等同于a大于子查询的最大值。

三、SOME 关键字

        SOME 是 ANY的一个同义词,功能相同。功能类似于逻辑原算符 或( or )。

select  *  from  table   where   a >  any( ... )

--  如果 any 后面跟的子查询返回的数据集中包含了 result1,result2,result3 三个值。

那么,上面的语句就可以看作:

select * from table  where a > result1 or a > result2 or a > result3;

--  即a大于子查询中的任意一个,等同于a大于子查询的最小值即可。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值