关于oracle多表联合查询的语句如何写?

有三张表如下:A表bhnamesl1a102b203c30B表bhnamesl11a52b203c25C表bhnamesl2sl31a502b200通过查询想得到如下结果... 有三张表如下:
A表
bh name sl
1 a 10
2 b 20
3 c 30
B表
bh name sl1
1 a 5
2 b 20
3 c 25
C表
bh name sl2 sl3
1 a 5 0
2 b 20 0
通过查询想得到如下结果:
bh name sl sl1 sl2 sl3
1 a 10 5 5 0
2 b 20 20 20 0
3 c 30 25
请问oracle中该如何写这个语句?
展开
 我来答
micro0369
推荐于2017-11-25 · TA获得超过1.2万个赞
知道大有可为答主
回答量:9250
采纳率:85%
帮助的人:4018万
展开全部
我给你写一个,保证能用,验证能用的话请采纳!!!

select all_.bh,all_.name,a.sl,b.sl1,c.sl2,c.sl3 from
(
select bh,name from a
union
select bh,name from b
union
select bh,name from c
) all_
left outer join a on all_.bh = a.bh and all_.name = a.name
left outer join b on all_.bh = b.bh and all_.name = b.name
left outer join c on all_.bh = c.bh and all_.name = c.name
百度网友090def6
2012-08-22 · TA获得超过2211个赞
知道小有建树答主
回答量:558
采纳率:100%
帮助的人:708万
展开全部
当数据记录条数不一致时,使用左联接查询:
select A.bh, A.name , sl, sl1,sl2,sl3
from A
left join B on A.bh= B.bh
left join C on A.bh= C.bh
追问
left join是以左表为主,我上面的三张表中并不一定是A表的数据多,可能A表有两条,B表有3条,结果要把三张表中所有的都显示出来
追答
这样的话是比较麻烦了,我再研究下
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2012-08-22
展开全部
select a.bn,a.name,a.s1,b.s2,c.s3
from a,b,c
where a.bh=b.bh and a.bh=c.bh
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友005985a
2012-08-22
知道答主
回答量:22
采纳率:0%
帮助的人:5.6万
展开全部
select * from A
union all
select * from B
union all
select * from C
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
flyingFish211
2012-08-22 · TA获得超过2.1万个赞
知道大有可为答主
回答量:1.5万
采纳率:50%
帮助的人:1.1亿
展开全部
Try this:

SELECT t.bh, t.name, max(a.sl), max(b.sl1), max(c.sl2), max(c.sl3)
from (SELECT DISTINCT bh, name from a
UNION SELECT DISTINCT bh, name from b
UNION SELECT DISTINCT bh, name from c) t
LEFT JOIN a ON t.bh = a.bh and t.name = a.name
LEFT JOIN b ON t.bh = b.bh and t.name = b.name
LEFT JOIN c ON t.bh = c.bh and t.name = c.name
GROUP BY t.bh, t.name
ORDER BY t.bh
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式