(首先声明一下,本篇文章是要查询表的所有数据)
参考: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