参考资料
1 oracle中关于in和exists,not in 和 not exists
[url]http://blogold.chinaunix.net/u/32484/showart_270855.html[/url]
2 oracle中的exists 和not exists 用法详解
[url]http://hi.baidu.com/qianyiliang/blog/item/54db82c2ca71fe1d0ef477a1.html[/url]
3 Oracle select in/exists/not in/not exits
[url]http://blog.csdn.net/adwfcu/archive/2008/11/19/3336468.aspx[/url]
[color=red]总结如下:
1 in 用于 右边表小的情况
2 exists 用于右边表大的情况
3 not exists效率比not in 快[/color]
具体介绍
in和exists
in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询
如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in:
例如:表A(小表),表B(大表)
1:
select * from A where cc in (select cc from B)
效率低,用到了A表上cc列的索引;
select * from A where exists(select cc from B where cc=A.cc)
效率高,用到了B表上cc列的索引。
相反的
2:
select * from B where cc in (select cc from A)
效率高,用到了B表上cc列的索引;
select * from B where exists(select cc from A where cc=B.cc)
效率低,用到了A表上cc列的索引。
not in 和not exists
如果查询语句使用了not in 那么内外表都进行全表扫描,没有用到索引;
而not extsts 的子查询依然能用到表上的索引。
所以无论那个表大,用not exists都比not in要快。
1 oracle中关于in和exists,not in 和 not exists
[url]http://blogold.chinaunix.net/u/32484/showart_270855.html[/url]
2 oracle中的exists 和not exists 用法详解
[url]http://hi.baidu.com/qianyiliang/blog/item/54db82c2ca71fe1d0ef477a1.html[/url]
3 Oracle select in/exists/not in/not exits
[url]http://blog.csdn.net/adwfcu/archive/2008/11/19/3336468.aspx[/url]
[color=red]总结如下:
1 in 用于 右边表小的情况
2 exists 用于右边表大的情况
3 not exists效率比not in 快[/color]
具体介绍
in和exists
in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询
如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in:
例如:表A(小表),表B(大表)
1:
select * from A where cc in (select cc from B)
效率低,用到了A表上cc列的索引;
select * from A where exists(select cc from B where cc=A.cc)
效率高,用到了B表上cc列的索引。
相反的
2:
select * from B where cc in (select cc from A)
效率高,用到了B表上cc列的索引;
select * from B where exists(select cc from A where cc=B.cc)
效率低,用到了A表上cc列的索引。
not in 和not exists
如果查询语句使用了not in 那么内外表都进行全表扫描,没有用到索引;
而not extsts 的子查询依然能用到表上的索引。
所以无论那个表大,用not exists都比not in要快。