三个表的全连接查询(多表联合查询):替代full join

(首先声明一下,本篇文章是要查询表的所有数据)
参考:https://blog.csdn.net/u012410733/article/details/63684663

在mysql中没有full join。我们可以使用union来达到目的。

三个数据表:bas_goods , pur_goods ,pur_provider

1.当两个表时实现左连接:

select * from bas_goods left join pur_goods on bas_goods.id=pur_goods.id

2.当两个表时实现右连接:

select * from bas_goods right join pur_goods on bas_goods.id=pur_goods.id 

3.当两个表时实现全连接(full join不可行的情况):

select * from bas_goods left join pur_goods on bas_goods.id=pur_goods.id
union
select * from bas_goods right join pur_goods on bas_goods.id=pur_goods.id

使用union 是自动去除重复项,若想保留重复项: union all

4.当三个表时实现左连接:

select * from bas_goods 
//需要几个表实现就加几条
left join pur_goods on bas_goods.id=pur_goods.id 
left join pur_provider on bas_goods.id=pur_provider.id

5.当三个表时实现右连接:

select * from bas_goods 
//需要几个表实现就加几条
right join pur_goods on bas_goods.id=pur_goods.id 
right join pur_provider on bas_goods.id=pur_provider.id

6:当三个表时实现全连接:

这时我们再像 标题3 一样用union连接,查询三个表的数据表后会发现处于中间位置的数据表数据会不全,即不能得到 pur_goods 数据表中的全部数据。

因为先是左连接bas_goods,bas_goods表的数据会全部得到,然后右连接pur_provider,pur_provider中表的数据也会全部得到。

So:不建议三个表及以上再采用这个方式。

7:当三个表的id都相同时:

//只有id都相同的情况才得到所有的数据

select * from bas_goods,pur_goods,pur_provider where bas_goods.id=pur_goods.id and bas_goods.id=pur_provider.id

有知道三个及多个表的全连接如何查询的大佬欢迎留言:

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
在连接三个时,使用full join是不可行的。在SQL语句中,full join用于返回两个中的所有行,包括匹配和不匹配的行。但是当连接三个时,full join并不能满足我们的需求。 如果我们想要实现三个的完全连接,可以采用以下步骤: 1. 使用left join将第一个与第二个表连接起来,并选择需要的列。这将返回匹配的行以及第一个中不匹配的行。 2. 使用right join将第二个与第三个表连接起来,并选择需要的列。这将返回匹配的行以及第三个中不匹配的行。 3. 将前两个连接的结果使用union连接起来,得到最终的结果。这将包括第一个和第二个的匹配行,以及第一个与第二个不匹配的行和第二个与第三个不匹配的行。 以下是一个示例的SQL语句: ``` select * from bas_goods left join pur_goods on bas_goods.id = pur_goods.id union select * from pur_goods right join pur_provider on pur_goods.id = pur_provider.id ``` 这样就能够实现三个的连接,并返回符合条件的所有行。请注意,具体的名、连接条件和需要选择的列需要根据实际情况进行调整。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [三个全连接查询多表联合查询):替代full join](https://blog.csdn.net/weixin_43592907/article/details/106435408)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值