数据库优化

IN 和 EXISTS的区别

select * from t1 where t1.a in (select t2.a from t2)

select * from t1 where exists (select 1 from t2 where t1.a = t2.a)

简而言之,一般式:外表大,用IN;内表大,用EXISTS,如此,sql的执行效率会很高

IN 和 EXISTS的执行方式=>

执行方式:

EXISTS:通过使用EXISTS,Oracle会首先检查主查询,然后运行子查询直到它找到第一个匹配项,这就节省了时间。

IN:Oracle在执行IN子查询时,首先执行子查询,并将获得的结果列表存放在一个加了索引的临时表中。在执行子查询之前,系统先将主查询挂起,待子查询执行完毕,存放在临时表中以后再执行主查询。这也就是使用EXISTS比使用IN通常查询速度快的原因。

你可能感兴趣的