数据库中的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)