在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
exists和in的区别很小,几乎可以等价,但是sql优化中往往会注重效率问题,今天咱们就来说说exists和in的区别。 create table teacher ( tid int(3), tname varchar(20), tcid int(3) ); insert into teacher values(1,'tz',1); insert into teacher values(2,'tw',2); insert into teacher values(3,'tl',3); 例如: select tname from teacher exists(select * from teacher); 此sql语句等价于select tname from teacher 此sql返回为空,因为子查询并不存在这样的数据。 select ..from table where tid in (1,3,5) ; select * from A where id in (select id from B); 区别: select tname from teacher where exists (select * from teacher); 这里很明显,子查询查询所有,数据集大,使用exists,效率高。 select * from teacher where tname in (select tname from teacher where tid = 3); 这里很明显,主查询数据集大,使用in,效率高。 到此这篇关于sql中exists和in的语法与区别的文章就介绍到这了,更多相关sql中exists和in语法区别内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论