2011-11-30 67 views
0

我有以下表格:的SQL Server 2008 - 多列與值替換代碼

TABLE_1:

 
Value_ID  Value_Code_1  Value_Code_2  Value_Code_3 
1   465    325    129 

TABLE_2:

 
ID   Text 
465   this is a value 
325   this value is a different one 
129   hello world 

我需要替換TABLE_1代碼與來自Table_2的文本。我想解決這個問題的方式似乎很長很長,有沒有更快,更好的方法呢?我必須這樣做大約40列而不是3例如我的例子。

我的代碼:

 
Select 
    first.ID, 
    first.string_value, 
    second.string_value, 
    third.string_value 
from 
(
    Select 
     a.ID, 
     b.text as string_value 
    From 
     table_1 a 
     left join 
     table_2 b 
     on a.Value_Code_1 = b.ID 
) first 

left join on first.id = second.id 

(
    Select 
     a.ID, 
     b.text as string_value 
    From 
     table_1 a 
     left join 
     table_2 b 
     on a.Value_Code_2 = b.ID 
) second 

left join on first.id = third.id 
(
    Select 
     a.ID, 
     b.text as string_value 
    From 
     table_1 a 
     left join 
     table_2 b 
     on a.Value_Code_2 = b.ID 
) third 

謝謝。

+0

你一直在說**替換**。我不認爲這意味着你的想法。 – Yuck

+1

@yuck:公主新娘? :) – MatBailie

+0

@Dems:是的!我會把它稱爲**加入**作爲替換**,從而推斷您希望更新**數據。哦,語義... – Yuck

回答

2

你可以做到這一點簡單的,就像這樣:

Select 
    Table_1.ID, 
    v1.Text, 
    v2.Text, 
    v3.Text 
FROM Table_1 
LEFT JOIN Table_2 v1 ON Table_1.Value_code_1 = v1.id 
LEFT JOIN Table_2 v2 ON Table_1.Value_code_2 = v2.id 
LEFT JOIN Table_2 v3 ON Table_1.Value_code_3 = v3.id; 

你仍然需要做的是爲所有40列。

+1

我找到了一個更簡單的解決方案。我創建了一個函數,它返回文本,如果你給它一個ID,當我從表中選擇,而不是使用Value_Code我使用dbo.my_Function(Value_Code),它的工作原理。 – alexstr

0

我不知道這是或多或少高性能40連接,或者如果它是更容易與否,但它是值得考慮的選擇...

SELECT 
    Table1.Value_ID, 
    MAX(CASE WHEN Table1.Value_Code_1 = Table2.ID THEN Table2.Text ELSE NULL END) AS Text1, 
    MAX(CASE WHEN Table1.Value_Code_2 = Table2.ID THEN Table2.Text ELSE NULL END) AS Text2, 
    MAX(CASE WHEN Table1.Value_Code_3 = Table2.ID THEN Table2.Text ELSE NULL END) AS Text3, 
    MAX(CASE WHEN Table1.Value_Code_4 = Table2.ID THEN Table2.Text ELSE NULL END) AS Text4, 
    etc 
FROM 
    Table1 
LEFT JOIN 
    Table2 
    ON Table2.ID = Table1.Value_Code_1 
    OR Table2.ID = Table1.Value_Code_2 
    OR Table2.ID = Table1.Value_Code_3 
    OR Table2.ID = Table1.Value_Code_4 
GROUP BY 
    Table1.Value_ID 


如果你一定要規範你表1,它變得更容易了......

New Table1: 
> Value_ID, 
> Column_ID, 
> Value_Code 

New SQL: 
SELECT 
    Table1.Value_ID, 
    MAX(CASE WHEN Table1.Column_ID = 1 THEN Table2.Text ELSE NULL END) AS Text1, 
    MAX(CASE WHEN Table1.Column_ID = 2 THEN Table2.Text ELSE NULL END) AS Text2, 
    MAX(CASE WHEN Table1.Column_ID = 3 THEN Table2.Text ELSE NULL END) AS Text3, 
    MAX(CASE WHEN Table1.Column_ID = 4 THEN Table2.Text ELSE NULL END) AS Text4, 
    etc 
FROM 
    Table1 
LEFT JOIN 
    Table2 
    ON Table2.ID = Table1.Value_Code 
GROUP BY 
    Table1.Value_ID 

(這類似於使用UNPIVOT答案)