sql语句用法常用(inner join,left join,right join,cross join)

例子:   
  a表       id   name     b表     id     job   parent_id   
              1   张3                   1     23     1   
              2   李四                  2     34     2   

              3   王武                  3     34     4   

1、内连接(inner join)

select a.id,a.name,b.id,b.job,b.parent_id from a inner join b on a.id=b.parent_id;

  结果是     
  1   张3                   1     23     1   
  2   李四                  2     34     2   

2、外连接(left join 或 left outer join)

select a.id,a.name,b.id,b.job,b.parent_id from a left join b on a.id=b.parent_id;

  结果是     
  1   张3                    1     23     1   
  2   李四                  2     34     2   
  3   王武                  null   

3、右连接(right join或 right outer join)

select a.id,a.name,b.id,b.job,b.parent_id from a right join b on a.id=b.parent_id;

  结果是     
  1   张3                   1     23     1   
  2   李四                 2     34     2   
  null                       3     34     4 

4、全连接(full join)

select a.id,a.name,b.id,b.job,b.parent_id from a full join b on a.id=b.parent_id;

结果是     
  1   张3                   1     23     1   
  2   李四                 2     34     2   
  null                 3     34     4   
  3   王武                 null

5、交叉连接(cross join)

select * from a cross join b;

结果是

1   张3                   1     23     1  

1   张3                   2     34     2   

1   张3                   3     34     4   

2   李四                  1     23     1

2   李四                  2     34     2   

2   李四                  3     34     4 

3   王武                  1     23     1

3   王武                  2     34     2   

3   王武                  3     34     4 


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值