oracle中all、any函数用法与区别说明
基础概念
在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:公用用户名或角色名无效的解决方式,ORA-65096错误意味着你在创建一个新的用户或角色时,使用了一个已经存在的公用用户名或角色名,需要的朋友可以参考下2024-05-05
Navicat Premium连接Oracle数据库的2种方式
这篇文章主要给大家介绍了关于Navicat Premium连接Oracle数据库的2种方式,大家要使用Navicat Premium连接Oracle数据库,请按照以下步骤操作,需要的朋友可以参考下2024-01-01
Centos7下oracle12c的安装与配置图文教程(详细)
这篇文章主要介绍了Centos7下oracle12c的安装与配置教程(详细),本文图文并茂通过实例代码相结合给大家讲解的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-11-11
Oracle数据库url连接最后一个orcl代表的是配置的数据库SID
今天小编就为大家分享一篇关于Oracle数据库url连接最后一个orcl代表的是配置的数据库SID,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2018-12-12


最新评论