oracle exists and not exist
来源:互联网 发布:access数据库还原 编辑:程序博客网 时间:2024/06/05 16:34
先看下面的例子:oracle中两个系统表.emp,dept.
example:
1:not exists(not in)
not exists:
这条语句返回select * from scott.dept d where e.deptno=d.deptno and d.deptno=10条件满足的结果集.也就是说,
返回的结果集中不存在d.deptno=10结果集的记录,即emp表中没有dept表中d.deptno=10的记录.
SQL> select empno,ename,deptno from scott.emp e where not exists(select * from scott.dept d where e.deptno=d.deptno and d.deptno=10);
EMPNO ENAME DEPTNO
----- ---------- ------
7369 SMITH 20
7499 ALLEN 30
7521 WARD 30
7566 JONES 20
7654 MARTIN 30
7698 BLAKE 30
7788 SCOTT 20
7844 TURNER 30
7876 ADAMS 20
7900 JAMES 30
7902 FORD 20
11 rows selected
not in:
第一个where条件必须给定字段(deptno), 第二个sql语句中,必须明确给定要查询的字段是哪个(deptno).
SQL> select empno,ename,deptno from scott.emp e where deptno not in(select deptno from scott.dept d where e.deptno=d.deptno and d.deptno=10);
EMPNO ENAME DEPTNO
----- ---------- ------
7369 SMITH 20
7499 ALLEN 30
7521 WARD 30
7566 JONES 20
7654 MARTIN 30
7698 BLAKE 30
7788 SCOTT 20
7844 TURNER 30
7876 ADAMS 20
7900 JAMES 30
7902 FORD 20
11 rows selected
2: exists(in)
exists:
这条语句返回select * from scott.dept d where e.deptno=d.deptno and d.deptno=10条件满足的记录结果集.
也就是说返回的结果集中只存在有d.deptno=10的记录,即emp表中只存在dept表中d.deptno=10的记录.
SQL> select empno,ename,deptno from scott.emp e where exists(select * from scott.dept d where e.deptno=d.deptno and d.deptno=10);
EMPNO ENAME DEPTNO
----- ---------- ------
7782 CLARK 10
7839 KING 10
7934 MILLER 10
in:
第一个where条件必须给定字段(deptno), 第二个sql语句中,必须明确给定要查询的字段是哪个(deptno).
SQL> select empno,ename,deptno from scott.emp e where deptno in(select deptno from scott.dept d where e.deptno=d.deptno and d.deptno=10);
EMPNO ENAME DEPTNO
----- ---------- ------
7782 CLARK 10
7839 KING 10
7934 MILLER 10
oracle 中exists (in)和not exists(not in)是判断是否存在和不存在表中记录的关键子.
请注意:not in 逻辑上不完全等同于not exists,如果你误用了not in,小心你的程序存在致命的BUG:因此,请尽量不要使用not in(它会调用子查询),而尽量使用not exists(它会调用关联子查询)。
- oracle exists and not exist
- oracle exists and not exist
- oracle exists and not exists
- EXISTS and NOT EXISTS
- oracle in,exists,not in,not exists
- MYSQL IF NOT EXISTS AND IF EXISTS
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- oracle中的exists 和not exists 用法
- Oracle 中的 exists 和 not exists 用法
- ASP.NET SqlDataSource中使用web.config 共享数据库连接字符串(详细)
- 关于数据类型Char(看了论坛的帖子后自己写的)——原来一个中文字在java中也是一个char
- 冰封王座打疯狂的电脑
- 工作流参与者和工作项模式分析
- 由Insert排序和Merge排序说起
- oracle exists and not exist
- SQL语句大全
- WindowsAPI 注册表函数总结
- windows系统启动过程原理全面分析
- 笔记本电池概述
- 存储过程参数长度
- 数据库三范式
- 生意经:网店营销要搭强者的便车
- 双色球现1400万巨奖 创单注最高奖金纪录