`

oracle exists and not exist

阅读更多
先看下面的例子: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使用

    - **内层Exists**: `NOT EXISTS(SELECT * FROM sc WHERE cno = course.cno AND sno = student.sno)` 检查是否有学生没有选修某门课程。这里的关键是,对于每一个 `course` 和 `student` 的组合,如果找不到相应的...

    Oracle In和exists not in和not exists的比较分析

    in和exist的区别 从sql编程角度来说,in直观,exists不直观多一个select, in可以用于各种子查询,而exists好像只用于关联子查询 从性能上来看 exists是用loop的方式,循环的次数影响大,外表要记录数少,内表就...

    oracle判断表名是否存在

    DBMS_OUTPUT.PUT_LINE('Table does not exist.'); END IF; EXCEPTION WHEN NO_DATA_FOUND THEN DBMS_OUTPUT.PUT_LINE('Table does not exist.'); END; / ``` 4. **使用`DBMS_METADATA.GET_DDL`包**: 这...

    oracle常见错误号

    9. ORA-00942:table or view does not exist - 表或视图不存在。确保表或视图已创建,并且拼写和大小写正确。 10. ORA-12560:TNS:protocol adapter error - 连接问题,可能是网络问题、配置错误或监听器问题。...

    oracle sqL 性能优化1

    #### 十七、NOT EXIST与NOT IN的区别 NOT IN在某些情况下可能无法正常工作,尤其是在处理NULL值时。此时使用NOT EXISTS是一个更好的选择,因为它可以正确处理NULL值。 #### 十八、利用EXISTS代替COUNT DISTINCT ...

    oracle性能问题总结

    - **避免使用Not In**:Not Exists通常优于Not In。 - **避免使用DISTINCT**:在一对多查询时,应避免在SELECT中使用DISTINCT,可以考虑使用EXIST替换。 - **避免计算索引列**:索引列不应参与计算,避免IS NULL...

    oracle积累

    PRINT 'Column does not exist'; END ``` - **示例**: ```sql IF EXISTS (SELECT * FROM sys.columns WHERE object_id = OBJECT_ID('PartStock') AND name = 'PartVelocity') BEGIN PRINT 'PartVelocity ...

    MySQL启动报错问题InnoDB:Unable to lock/ibdata1 error

    通过`sudo launchctl unload -w /Library/LaunchDaemons/com.oracle.oss.mysql.mysqld.plist`命令停止MySQL服务,然后使用`sudo launchctl load -w /Library/LaunchDaemons/com.oracle.oss.mysql.mysqld.plist`启动...

    如何从Oracle的存储过程中访问操作系统的资源.pdf

    throw new SQLException("Path does not exist or is not a directory: " + path); } } } ``` 接下来,你需要将这个Java源码编译并加载到Oracle数据库中,这可以通过以下PL/SQL语句完成: ```sql BEGIN DBMS_...

    orcale精典代码

    怎样删掉主键,exist及not exists的精典代码,感觉不错

    SQL优化之针对count、表的连接顺序、条件顺序、in及exist的优化

    在Oracle 10g中,如果子查询中的`deptno`总是非空,`IN`和`EXISTS`的效率是相同的。而在Oracle 11g及更高版本中,无论子查询结果是否包含空值,两者效率都相仿。因此,选择`IN`还是`EXISTS`应基于具体环境和数据特性...

    sql 书写规范

    1. 尽量少用嵌套查询,如必须,请用 not exist 代替 not in 子句。 2. 用多表连接代替 EXISTS 子句。 3. 少用 DISTINCT,用 EXISTS 代替。 4. 使用 UNION ALL、MINUS、INTERSECT 提高性能。 5. 使用 ROWID 提高检索...

    SQL21日自学通

    Table or View Does Not Exist471 Invalid Username or Password 472 FROM Keyword Not Specified473 Group Function Is Not Allowed Here 474 Invalid Column Name475 Missing Keyword 475 Missing Left ...

    SQLException

    3. **ORA-00942: table or view does not exist** - **含义**:试图访问的表或视图不存在。 - **解决方法**:检查表或视图名称是否正确,以及是否已经被删除或重命名。 4. **ORA-01400: cannot insert NULL into...

    在jar包在查找指定的文件是否存在工具

    System.out.println("File " + targetFileName + " does not exist in the JAR."); } } } ``` 在上述代码中,`containsFileInJar`方法接受JAR文件路径和目标文件名,然后检查该文件是否存在于JAR中。`main`方法...

    一些简单的小命令

    echo "File does not exist." fi ``` - 条件测试:使用方括号 `[]`,注意空格的使用。 - `[-f "somefile"]` 检查是否为文件。 - `[-x "/bin/ls"]` 检查是否可执行。 - `[-n "$var"]` 检查变量是否有值。 - `...

Global site tag (gtag.js) - Google Analytics