日期:2014-05-20  浏览次数:20440 次

救命。~~~~~ 很难的一个问题,难倒了好几个QQ群的问题。
有两个数据表
表1                  
A     C       D
1     a       1
2     b       2
3     c       2
4     d       32
表2
A     F       G
2     f       3
3     g       1
4     h       2
   
现在想实现这样的结构。
A   a   b   c   d     e   f   g   h  
1   1   .   .   .     .   .   .   .
2   .   2   .   .     .   3   .   .  
3   .   .   2   .     .   .   1   .
4   .   .   .   32   .   .   .   2
". "代表空

救命     要不就被开除了  


------解决方案--------------------
不知所云,帮顶
------解决方案--------------------
交叉表啊.
------解决方案--------------------
DECLARE @Sql nvarchar(4000) SET @Sql = 'SELECT A ' SELECT @sql = @sql + ',SUM(case C when ' ' '+ C + ' ' ' then D Else null end) as ' + C FROM (SELECT A,C, D FROM T1 UNION ALL SELECT A,F,G FROM T2) AS AA set @sql = @sql + ' from (Select * FROM t1 union select * FROM t2) AS AA GROUP BY A ' exec(@sql)
------解决方案--------------------
lz把上面的sql写成个存储过程调用就可以了.
------解决方案--------------------
这样实现是可以,但是效率不高,如果数据量大的话会有问题.
------解决方案--------------------
Drop table a
drop table b
Create table a
(
A int,
C nvarchar(10),
D int
)
go

Create table b
(
A int,
F nvarchar(10),
G int
)
go

insert into a select 1, 'a ',1
union all
select 2, 'b ',2
union all
select 3, 'c ',2
union all
select 4, 'd ',32

insert into b select 2, 'f ',3
union all
select 3, 'g ',1
union all
select 4, 'h ',2


select C.A,max(case C when 'a ' then D end)as a ,max(case C when 'b ' then D end) as b,
max(case C when 'c ' then D end) as c,max(case C when 'd ' then D end)as d,
max(case F when 'f ' then G end)as f,max(case F when 'g ' then G end)as g,
max(case F when 'h ' then G end) as h
from (select a.A,C,D,F,G from a left join b on a.A=b.A)as C Group by C.A

A a b c d f g h
1 1 NULL NULL NULL NULL NULL NULL
2 NULL 2 NULL NULL 3 NULL NULL
3 NULL NULL 2 NULL NULL 1 NULL
4 NULL NULL NULL 32 NULL NULL 2



------解决方案--------------------
create table #t(a varchar(1),b int)

insert #t(
select C,D from 表1
union all
select F,G from 表2)

DECLARE @a varchar(1),@b int,strSQL varchar(2000)
set strSQL= 'create table ##mytaba (A int '
--游标#t动态生成表结构语句
DECLARE a_Cursor CURSOR FOR select a from #t
Open a_Cursor
FETCH NEXT FROM a_Cursor into @a
WHILE @@FETCH_STATUS = 0