三个表的全连接查询(多表联合查询):替代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

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

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值