数据库中的in与exists,not in与not exists问题总结以及注意事项

数据库中的in与exists,not in与not exists问题总结以及注意事项

数据库操作中,经常遇到in与exists,not in与not exists,从概念上来说功能相同,但从使用和实现上来说责不大相同,现在就以上四个方便做简单的对比分析以及使用注意事项总结,以供参考查阅

一、in和exists

in是把外表和内表作hash连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询,一直以来认为exists比in效率高的说法是不准确的。如果查询的两个表大小相当,那么用in和exists差别不大;如果两个表中一个较小一个较大,则子查询表大的用exists,
子查询表小的用in;

select * from A where id in(select id from B)

使用in语句,in()只执行一次,它查出B表中的所有id字段并缓存起来.之后,检查A表的id是否与B表中的id相等,如果相等则将A表的记录加入结果集中,直到遍历完A表的所有记录.
它的查询过程类似于以下过程

    List resultSet=[];
    Array A=(select * from A);
    Array B=(select id from B)

你可能感兴趣的:(数据库,Oracle,in与exists,not,in与not,exists)