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 dbca时报:ORA-12547: TNS:lost contact错误的解决
这篇文章主要给大家介绍了关于Oracle在dbca时报:ORA-12547: TNS:lost contact错误的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。2017-11-11解决Oracle 查询时报错ORA-00923: FROM keyword not found where
这篇文章主要介绍了解决Oracle 查询时报错ORA-00923: FROM keyword not found where expected的问题,主要给大家介绍可能发生报错的几种情况,感兴趣的朋友跟随小编一起看看吧2023-03-03解决Oracle DISTINCT 报错 inconsistent datatypes: expected
这篇文章主要介绍了Oracle DISTINCT报错inconsistent datatypes:expected-got CLOB(数据类型不一致: 应为-,但却获得 CLOB),本文给大家分享三种解决方案,需要的朋友可以参考下2023-07-07
最新评论