IN:Oracle在执行IN子查询时,首先执行子查询,并将获得的结果列表存放在一个加了索引的临时表中。在执行子查询之前,系统先将主查询挂起,待子查询执行完毕,存放在临时表中以后再执行主查询。
EXISTS:Oracle会首先检查主查询,然后运行子查询直到它找到第一个匹配项,每次扫描为真时就返回,继续往下走。
如果数据量很小的话,in和exists的差距是忽略不计的,但数据量很大时差距就很大了!
IN:Oracle在执行IN子查询时,首先执行子查询,并将获得的结果列表存放在一个加了索引的临时表中。在执行子查询之前,系统先将主查询挂起,待子查询执行完毕,存放在临时表中以后再执行主查询。
EXISTS:Oracle会首先检查主查询,然后运行子查询直到它找到第一个匹配项,每次扫描为真时就返回,继续往下走。
如果数据量很小的话,in和exists的差距是忽略不计的,但数据量很大时差距就很大了!