Oracle中in和exists的区别是什么

本篇文章给大家分享的是有关Oracle中in和exists的区别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

目前创新互联公司已为上千家的企业提供了网站建设、域名、虚拟主机成都网站托管、企业网站设计、曹妃甸网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

一、第一种情况

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

效率高,这里用到的是大表A上的索引

select * from B exists (select mm from A where mm=B.mm)

效率高,这里用到的是小表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上的索引

三、第三种情况

not exists 在使用时依然会用到表上的索引,但是not in会进行全盘扫描

因此,not exists 始终比not in 的效率高

四、第四种情况

in与==效果是相同的

以上就是Oracle中in和exists的区别是什么,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注创新互联行业资讯频道。


标题名称:Oracle中in和exists的区别是什么
文章起源:http://bzwzjz.com/article/jdphej.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站建设 成都网站设计 手机网站制作 成都网站建设 成都网站建设 网站建设 成都网站设计 成都网站制作 成都网站建设 成都网站建设 成都响应式网站建设公司 上市集团网站建设 定制网站设计 成都网站设计制作公司 成都网站建设 成都网站建设公司 企业网站建设 企业网站设计 成都网站设计 成都企业网站建设公司 成都网站建设 专业网站设计