ITPub博客

首页 > Linux操作系统 > Linux操作系统 > not in 用外连接实现

not in 用外连接实现

原创 Linux操作系统 作者:wei-xh 时间:2012-02-01 14:47:32 0 删除 编辑
sys@CRMCN>select * from test;
        ID       NAME
---------- ----------
         1          2
         2          3
sys@CRMCN>select * from test1;
        ID       NAME
---------- ----------
         1          2
         2          3
sys@CRMCN>select
  2  test.*
  3  from
  4  test,
  5  test1
  6  where
  7  test1.id(+) = test.id
  8  and test1.name(+) = 2
  9  and test1.id is null
 10  ;
        ID       NAME
---------- ----------
         2          3
        
等价于:
select test.*
from test
where test.id not in (
select test1.id
from test1
where test1.name = 2
)
;
sys@CRMCN>select * from
  2  test,
  3  test1
  4  where
  5  test1.id(+) = test.id
  6  and test1.name(+) = 2;
        ID       NAME         ID       NAME
---------- ---------- ---------- ----------
         1          2          1          2
         2          3
sys@CRMCN>select * from
  2  test,
  3  test1
  4  where
  5  test1.id(+) = test.id;
        ID       NAME         ID       NAME
---------- ---------- ---------- ----------
         1          2          1          2
         2          3          2          3
连接以后。对于test1.name不为2的记录,整条记录用null值代替。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22034023/viewspace-715426/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
Oracle ACE组成员,DBGeeK用户组发起人。曾在DTCC、ORACLE技术嘉年华、Gdevops等公开场合做过数据库技术专题分享,2017年应Oracle邀请在世界最大的数据库会议OOW上做技术分享。组织翻译了《拨云见日,解密Oracle ASM内核》一书。

注册时间:2009-07-04

  • 博文量
    422
  • 访问量
    2285135