源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

简述Oracle中in和exists的不同

  • 时间:2021-01-10 23:28 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:简述Oracle中in和exists的不同
一直以来,大家认为exists比in速度快,其实是不准确的。且看接下来的具体分析:in其实是将外表和内表进行hash join,exists是先对外表进行loop操作,然后每次loop后再对内表进行查询。 如果两张表大小差不多,那么exists和in的效率差不多。 例如: 一张大表为A,一张小表B [b]一、第一种情况[/b]
select * from A where mm in (select mm from B)
效率高,这里用到的是大表A上的索引
select * from B exists (select mm from A where mm=B.mm)
效率高,这里用到的是小表B上的索引 [b]二、第二种情况[/b]
select * from B where mm in (select mm from A)
效率低,这里用到的是小表B上的索引
select * from A exists (select mm from B where mm=A.mm)
效率高,这里用到的是大表A上的索引 [b]三、第三种情况[/b] not exists 在使用时依然会用到表上的索引,但是not in会进行全盘扫描 因此,not exists 始终比not in 的效率高 [b]四、第四种情况[/b] in与==效果是相同的 [b]总结[/b] 以上所述是小编给大家介绍的Oracle中in和exists的不同,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部