2013-06-01 139 views
0

我有一個數據樞軸連接的表SQL Server上

TAB1

--------------------------------------------- 
    | ID1 | ID2 | SIGNEDBY | A | B | C | 
    | 1 | 8 | 'aa' |'John' | 9 | 12/12 | 
    | 2 | 9 | 'bb' |'Smith' | 0 | 13/12 | 

TAB2

------------------------------------------------------------------- 
    | NAME | ID1 | ID2 | SIGNEDBY | VSTRING | VINT | VDATA | D | E | 
    | 'C1' | 1 | 8 | 'aa' | NULL | 1 | NULL | 'l'| 5 | 
    | 'C2' | 1 | 8 | 'aa' | 'sth' | NULL | NULL | 'p'| 4 | 
    | 'C3' | 1 | 8 | 'aa' | NULL | NULL | 12/1/13 | 'q'| 5 | 
    | 'C2' | 2 | 9 | 'bb' | 'oth' | NULL | NULL | 'p'| 4 | 
    | 'C3' | 2 | 9 | 'bb' | NULL | NULL | 1/1/11 | 'q'| 5 | 

我需要的,這將產生一個查詢兩個表

TAB3

---------------------------------------------------- 
    | ID1 | ID2 | A | B | C1 | C2 | c3 | 
    | 1 | 8 | 'John' | 9 | 1 | 'sth' | 12/1/13 | 
    | 2 | 9 | 'Smith'| 0 | NULL | 'oth' | 1/1/11 | 

首先我想在本地創建TAB3,插入數據形成TAB1到TAB3,然後爲每個我叫名字「合併爲表」。它工作正常,但速度太慢(超過4分鐘)。然後我嘗試了一個查詢,如:

Select ID1, ID2, A, (Select VINT from TAB3 where Name - 'C1' and ....) 'C1', 
    .... from TAB1 

這也是工作正常,但仍然太慢。然後我遇到了pivot命令,但是我沒有設法編寫一個工作代碼。是否可以爲這個問題編寫一個快速查詢(理想情況下是一個)?

+0

能否請你解釋一下輸出你想?此外,[SQLFiddle](http://sqlfiddle.com)中的示例將非常棒。 – vidit

+0

TAB1上的哪個字段標識TAB2上的對應字段 - ID1,ID2和/或SIGNEDBY? –

+0

字段ID1,ID2,SIGNEDBY對應於TAB1和TAB2之間 – orwe

回答

0

這裏的另一種選擇使用MAXPIVOT你的結果與CASE不需要加入表回自己:

select t.id1, t.id2, t.a, t.b, 
    max(case when t2.name = 'C1' then t2.vint end) c1, 
    max(case when t2.name = 'C2' then t2.vstring end) c2, 
    max(case when t2.name = 'C3' then t2.vdata end) c3 
from tab1 t 
    left join tab2 t2 on t.id1 = t2.id1 and t.id2 = t2.id2 
group by t.id1, t.id2, t.a, t.b 
0

嘗試:

select t.id1, t.id2, t.a, t.b, c1.vint c1, c2.vstring c2, c3.vdata c3 
from tab1 t 
left join tab2 c1 
    on t.id1=c1.id1 and t.id2=c1.id2 and t.signedby=c1.signedby and c1.name='C1' 
left join tab2 c2 
    on t.id1=c2.id1 and t.id2=c2.id2 and t.signedby=c2.signedby and c2.name='C2' 
left join tab2 c3 
    on t.id1=c3.id1 and t.id2=c3.id2 and t.signedby=c3.signedby and c3.name='C3'