oracle join

 假设a表和b表的数据是这样的。  
  a                         b    
  id     name  id     stock   
  
1  a             1         15  
  
2         b             2         50  
  
3         c                  
   
  
select   *   from   a   inner   join   b   on   a.id=b.id  
  这个语法是连接查询中的内连接,它产生的结果是  
  两个表相匹配的记录出现在结果列表中。  
  根据上面的表,出现的结果是这样的  
  a.id     name     b.id     stock  
  
1       a             1         15  
  
2             b             2         50  
  
----------------------------  

select   *   from   a,b   where   a.id=b.id  

  这个语法是内连接的另外一种写法,其执行结果与inner   join   一样  

  -- ------------------------------    
   
   select    *    from   a    left / right    join   b    on   a.id =b.id  
  这个是外连接语法中的左外连接或右外连接  
  如果是左外连接的话,它将显示a表的所有记录,  
   select   a. *,b. *    from   a    left    join   b    on   a.id =b.id  
  查询的结果是这样的:  
  a.id     name     b.id     stock  
   1         a          1              15  
   2               b          2              50  
   3               c        null          null   
   -- ------------------------------------------  
  如果是右外连接的话,它将显示b表的所有记录,  
   select   a. *,b. *    from   a    right    join   b    on   a.id =b.id  
  查询的结果是这样的:  
  a.id     name     b.id     stock  
   1         a          1              15  
   2               b          2              50   

select   a.*,b.*   from   a   left   join   b   on   a.k   =   b.k    
  
select   a.*,b.*   from   a   left   outer   join   b   on   a.k   =b.k  
  
----------上面两种一样left   join是left   outer   join的简写  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值