SQL - 基于(从第一个表到第二个表的列值的行值)将一个表与另一个表连接起来

时间:2012-04-20 10:07:07

标签: sql sql-server join left-join

我有两张表,如下所示

第一张表:

   DealNum      CurrencyValue      CurrencyCode       Date

    110             100                 AA         01/12/2011  
    111             200                 AB         01/11/2011
    112             120                 AC         01/10/2011  
    113             20                  AA         01/11/2011
    110             103                 AD         01/12/2011  
    115             200                 AD         01/11/2011
    119             120                 AG         01/10/2011  
    130             20                  AK         01/11/2011

第二张表

   CurrencyCode     OCT       NOV      DEC     JAN   ..

      AA             0.91     0.88     0.9     0.94  
      AB             0.9      0.8      0.96    0.89
      AC             0.81     0.79     0.82    0.84  
      AD             0.4      0.41     0.42    0.39
      AE             0.9      0.92     0.91    0.94  
      AF             0.8      0.82     0.83    0.81

现在我想将第二个表中的数据添加到具有以下条件的新列中的第一个表

1.It has to do based on the CurrencyCode and month
2.If the deal is from DEC and currencyCode is AA , then it has to take the value 0.9,
  if the deal is from NOV and currencyCode is AA , then it has to take the value 0.88..

所以,结果应该是这样的

   DealNum      CurrencyValue      CurrencyCode       Date        NewColumn

    110             100                 AA         01/12/2011        0.9
    111             200                 AB         01/11/2011        0.8
    112             120                 AC         01/10/2011        0.81  
    113             20                  AA         01/11/2011        0.88
    110             103                 AD         01/12/2011        0.42
    115             200                 AD         01/11/2011        0.41
    119             120                 AG         01/10/2011         --
    130             20                  AK         01/11/2011         --

我不清楚如何通过将第一个表的月份行值与第二个表中的月份列值进行比较来完成此操作。请帮帮我...

提前致谢。

干杯, 哈里什。

1 个答案:

答案 0 :(得分:1)

这应该有效,尽管你的第二张桌子设计得不好。

SELECT   DealNum      
       , CurrencyValue      
       , CurrencyCode       
       , Date
       , Deal = 
         CASE MONTH(t1.Date)
           WHEN 1 THEN t2.JAN
           WHEN 2 THEN t2.FEB
           WHEN 3 THEN t2.MAR
           -- .....
           WHEN 10 THEN t2.OCT
           WHEN 11 THEN t2.NOV
           WHEN 12 THEN t2.DEC
        END
FROM Table1 t1 
INNER JOIN Table2 t2 ON t1.CurrencyCode = t2.CurrencyCode