Oracle IN 与NOT IN 的性能区别

2014-11-24 18:16:16 · 作者: · 浏览: 0

业务问题大概可以这样描述,一个父表,一个子表,查询的结果是找到子表中没有使用父表id的记录,这种情况估计很多系统都会牵涉得到。让我们来举一个例子:


  表一: 父表 parent



  表二: 子表 childen



  父表存储父亲,子表存储孩子,然后通过pid和父表关联,查询需要的结果是找到尚未有孩子的父亲。


  我们来看一下查询语句的写法:


  select * from parent where id not in (select pid from childen)


  这种标准的写法在子表存在50万条的记录的时候,查询时间超过了10秒,远远大于原来的sql server服务器的一秒。我在解决的时候想到了一个方法:


  select * from parent where id in


  ( select id from parent minus select pid from childen )


  正常理解下,这个语句应该更加费时,但是事实完全出乎意料,这条语句不仅仅在子表存在大量记录的情况下速度良好,在子表少量数据的情况下速度也非常的好,基本在1秒内完成。