oracle中all、any函数用法与区别说明

 更新时间:2023年04月15日 10:25:32   作者:努力的小羽儿  
在Oracle中,any()表示括号内任何一个条件,只要有一个满足即可;而all()表示所有的条件都满足才可以

基础概念

在Oracle中,any()表示括号内任何一个条件,只要有一个满足即可;而all()表示所有的条件都满足才可以。

代码演示

1.all用法

--大于最大值
select * from A where id >= all(select id from A)
--这相当于
select * from A where id >= (select max(id) from A)
 
--小于最小值
select * from A where id <= all(select id from A)
--这相当于
select * from A where id <= (select min(id) from A)

2.any用法 

--大于任意一个数即可,大于最小值
select * from A where id >= any(select id from A)
--这相当于
select * from A where id >= (select min(id) from A)
 
--小于任意一个数即可,小于最大值
select * from A where id <= any(select id from A)
--这相当于
select * from A where id <= (select max(id) from A)

Oracle中any和all的区别用法

对于any,all的用法,书中说的比较绕口,难以理解,如果通过举例就会比较清晰.

any的例子:

select * from t_hq_ryxx where gongz > any (select pingjgz from t_hq_bm);

输出的结果是所有大于字段‘pingjgz‘中最小数的值,简单来说就是输出的数全部大于‘pingjgz‘字段中的最小值;

select * from t_hq_ryxx where gongz < all (select pingjgz from t_hq_bm);

输出的结果是所有小于字段‘pingjgz‘中最大数的值,简单来说就是输出的数全部小于‘pingjgz‘字段中的最大值;

即:大于最小值,小于最大值

all的例子:

select * from t_hq_ryxx where gongz > all (select pingjgz from t_hq_bm);

输出的结果是所有大于字段‘pingjgz‘中最大数的值,简单来说就是输出的数全部大于‘pingjgz‘字段中的最大值;

select * from t_hq_ryxx where gongz < all (select pingjgz from t_hq_bm);

输出的结果是所有小于字段‘pingjgz‘中最小数的值,简单来说就是输出的数全部小于‘pingjgz‘字段中的最小值;

即:小于最小值,大于最大值

如果还是不清楚,把下面这句看懂也就够了:

any 就是匹配集合中的任意一个就满足条件了;而 all 要跟所有的都比较,所有都满足以后才为真。

相关文章

  • oracle创建用户时报错ORA-65096:公用用户名或角色名无效解决方式

    oracle创建用户时报错ORA-65096:公用用户名或角色名无效解决方式

    这篇文章主要给大家介绍了关于oracle创建用户时报错ORA-65096:公用用户名或角色名无效的解决方式,ORA-65096错误意味着你在创建一个新的用户或角色时,使用了一个已经存在的公用用户名或角色名,需要的朋友可以参考下
    2024-05-05
  • oracle select执行顺序的详解

    oracle select执行顺序的详解

    本篇文章是对oracle select执行顺序进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • Navicat Premium连接Oracle数据库的2种方式

    Navicat Premium连接Oracle数据库的2种方式

    这篇文章主要给大家介绍了关于Navicat Premium连接Oracle数据库的2种方式,大家要使用Navicat Premium连接Oracle数据库,请按照以下步骤操作,需要的朋友可以参考下
    2024-01-01
  • Centos7下oracle12c的安装与配置图文教程(详细)

    Centos7下oracle12c的安装与配置图文教程(详细)

    这篇文章主要介绍了Centos7下oracle12c的安装与配置教程(详细),本文图文并茂通过实例代码相结合给大家讲解的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-11-11
  • oracle delete误删除表数据后如何恢复

    oracle delete误删除表数据后如何恢复

    最近在使用oracle数据时,一不小心把table中的数据delete掉并且已经提交了,下面这篇文章主要给大家介绍了关于oracle delete误删除表数据后如何恢复的相关资料,需要的朋友可以参考下
    2022-06-06
  • oracle行转列与列转行的几种方式汇总

    oracle行转列与列转行的几种方式汇总

    最近项目需要进行行转列,经过上网查找到了一些解决方法,分享给大家,这篇文章主要给大家介绍了关于oracle行转列与列转行的几种方式,文中通过图文以及实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • 解决Oracle字符串中包含数字、特殊符号的排序问题

    解决Oracle字符串中包含数字、特殊符号的排序问题

    最近做项目遇到这样的需求,要求实现某小区需要按照小区、楼栋、单元号、房间号进行排序。看似很简单的一个需求,一条sql语句搞定,其实套路很深,下面小编给大家分享下Oracle字符串中包含数字、特殊符号的排序问题
    2017-11-11
  • Oracle数据库url连接最后一个orcl代表的是配置的数据库SID

    Oracle数据库url连接最后一个orcl代表的是配置的数据库SID

    今天小编就为大家分享一篇关于Oracle数据库url连接最后一个orcl代表的是配置的数据库SID,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • Oracle收购TimesTen 提高数据库软件性能

    Oracle收购TimesTen 提高数据库软件性能

    Oracle收购TimesTen 提高数据库软件性能...
    2007-03-03
  • Oracle数据库的两种授权收费方式详解

    Oracle数据库的两种授权收费方式详解

    现在Oracle有两种授权收费方式,按CPU(Process)数和按用户数(Named User Plus),前一种方式一般用于用户数不确定或者用户数量很大的情况,典型的如互联网环境,这篇文章主要介绍了Oracle数据库的两种授权收费方式介绍,需要的朋友可以参考下
    2022-10-10

最新评论