首頁 > 資料庫 > mysql教程 > Oracle中的Exists、In、ANY、ALL

Oracle中的Exists、In、ANY、ALL

WBOY
發布: 2016-06-07 15:19:46
原創
1366 人瀏覽過

Exists:子查询至少返回一行时条件为true。 Not Exists:子查询不返回任何一行时条件为true。 In:与子查询返回结果集中某个相等。 Not In:与子查询返回结果集中任何一个不相等。 ANY:比子查询返回结果中的某个大。 =ANY:与子查询返回结果中的某个相等。

Exists:子查询至少返回一行时条件为true。

Not Exists:子查询不返回任何一行时条件为true。

In:与子查询返回结果集中某个值相等。

Not In:与子查询返回结果集中任何一个值不相等。

>ANY:比子查询返回结果中的某个值大。

=ANY:与子查询返回结果中的某个值相等。

>ALL:比子查询返回结果中的所有值都大。

1、查询与10号部门某个员工工资相等的员工信息。

select empno ,ename,sal from emp 
where sal in(select sal from emp where deptno=10)
登入後複製

下面这句话与上的语句效果一样

select empno ,ename,sal from emp 
where sal=any(select sal from emp where deptno=10)
登入後複製

效果如下图:

Oracle中的Exists、In、ANY、ALL

小注:

        =any()括号中即使出现重复的值,也不会报错,比如:

select empno ,ename,sal from emp 
where sal=any(2450.00,5000.00,5000.00)
登入後複製
2、查询比10号部门某个员工工资高的员工信息。
select empno ,ename,sal from emp 
where sal >any(select sal from emp where deptno=10)
登入後複製

在emp表中工资的最小值为1300,下面这句话与上面语句的效果一样

select empno ,ename,sal from emp 
where sal >1300
登入後複製

效果如下图:

Oracle中的Exists、In、ANY、ALL

3、查询比10号部门所有员工工资高的员工信息。

select empno ,ename,sal from emp 
where sal >all(select sal from emp where deptno=10)
登入後複製

效果如下图(没有查询到数据):

Oracle中的Exists、In、ANY、ALL


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板