日期:2014-05-17 浏览次数:20760 次
表A
ID time data
2 11:15 9
3 11:30 11
表B
ID time data
1 11:00 6
2 11:15 5
表C
ID time data
2 11:15 8
合并成如下
time A.data B.data C.data
11:00 6
11:15 9 5 8
11:30 11
select time,
max(case when c='A' then date else '' end)as A.data,
max(case when c='B' then date else '' end)as B.data,
max(case when c='C' then date else '' end)as C.data
from (
select time,data,'A' as c from A
union all
select time,data,'B' from B
union all
select time,data,'C' from C) a
group by time
with t1 as
(
select 2 c1,'11:15' c2,9 c3 from dual union all
select 3 c1,'11:30' c2,11 c3 from dual
),t2 as
(
select 1 c1,'11:00' c2,6 c3 from dual union all
select 2 c1,'11:15' c2,5 c3 from dual
),t3 as
(
select 2 c1,'11:15' c2,8 c3 from dual
)
select t.c2,t1.c3,t2.c3,t3.c3
from
(
select t1.c2
from t1
union
select t2.c2
from t2
union select t3.c2
from t3
) t left join t1 on t.c2 = t1.c2
left join t2 on t.c2 = t2.c2
left join t3 on t.c2 = t3.c2
c2 c3 c3 c3
---------------------------------------
1 11:00 6
2 11:15 9 5 8
3 11:30 11
with t1 as(
select '2' id,'11:15' time,'9' date1 from dual
union
select '3','11:30','11' from dual)
,t2 as(