一个跨国公司面试的SQL题目

 inner   join  
  left   outer   join  
  right   outer   join  
  full   outer   join  
  四者的区别  

cross join 是笛卡儿乘积 就是一张表的行数乘以另一张表的行数
a left join b:返回a的全部行--》b中满足的行以及b中没有满足的行(用null代替)
a right join b:同上不过是ab调换一下
full  join 返回两张表中的行 left join+right join
inner join 只返回两张表连接列的匹配项

a表  
  1,'x'  
  2,'y'  
  3,'z'  
   
  b表  
  1,'a'  
  4,'b'  
  5,'c'  
   
   
  inner   join   内连接:  
  select   a.id   ,a.name,b.id,b.name   from   a,b  
  where   a.id   =   b.id  
   
  1,'x',1,'a'  
   
  left   outer   join   左连接  
  select   a.id   ,a.name,b.id,b.name   from   a  
  left   outer   join   b   on   a.id   =b.id  
  1,'x',1,'a'  
  2,'y',null,null  
  3,'z',null,null  
   
  right   outer   join   右连接  
  select   a.id   ,a.name,b.id,b.name   from   a  
  right   outer   join   b   on   a.id   =b.id  
  1,'x',1,'a'  
  null,null,4,'b'  
  null,null,5,'c'  
   
  full   outer   join   外连接  
  select   a.id   ,a.name,b.id,b.name   from   a  
  full   outer   join   b   on   a.id   =b.id  
  1,'x',1,'a'  
  2,'y',null,null  
  3,'z',null,null  
  null,null,4,'b'  
  null,null,5,'c'  

转载于:https://www.cnblogs.com/yzxchoice/archive/2006/09/27/516152.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值