首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

oracle里边Union和minus的区别

2013-08-01 
oracle里面Union和minus的区别Oracle的in和not in(图)(图一) /  表二: 子表 childen     父表存储父亲,

oracle里面Union和minus的区别
Oracle的in和not in(图)(图一)" />
  表二: 子表 childen
   oracle里边Union和minus的区别


  父表存储父亲,子表存储孩子,然后通过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秒内完成。
  
  这个结果可以很明显的证明oracle 在子查询的内部处理的时候,使用 in 和 not in 的巨大区别,希望用到这种方式的用户注意,也期待有人解释其中的问题。

热点排行