内连接与外连接

最近一段时间找工作,对以往的知识进行了复习,以下是本人对数据库中表连接的总结:

 

连接:连接是指将关系数据库中的两个表根据内容一定的条件连接成一个表

 

连接类型:内连接与外连接

 

a、内连接:又称等值连接,如

 

Select a.*,b.* From TableA a,TableB b where a.id = b.id;

 

 也可以:

 

Select a.*,b.* From TableA a INNER JOIN TableB b ON a.id = b.id;

 

 

b、外连接(左外连接、右外连接、迫切左连接)

 

左外连接:以左表为基础来连接,如果左表的某行内容无法在右表中找到相对的row,则将右表统统用null来表示

 

Select a.*,b.* From TableA a LEFT JOIN TableB b ON a.id = b.id;

 

 

右外连接:以右表为基础来连接,如果右表的某行内容无法在左表中找到相对的row,则将左表统统用null来表示

 

Select a.*,b.* From TableA a RIGHT JOIN TableB b ON a.id = b.id;

 

 

迫切左连接:解决N+1问题

如:A表与B表相连,B表与C表相连。当A与B表左连接( LEFT JOIN)时,在加载B的同时,也会加载与B相关联的C表;

                                                  当A与B表迫切左连接时(LEFT JOIN FETCH),只保证加载需要的实体,即B

 

Select a.*,b.* From TableA a LEFT JOIN FETCH TableB b 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值