oracle中left join和right join的区别浅谈


当前第2页 返回上一页

  4                      c                     4                      z      --

举个例子: 

   假设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的简写 

  select    a.*,b.*   from    a   left   inner   join    b   on    a.k   =    b.k   

   没有这种写法,错误的语句.


打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...