我覺得一般的做法是這樣的:
select
D1.Dim1, D2.Dim2,
sum(case when M.Month = 1 then C.Cost end) as [1],
sum(case when M.Month = 2 then C.Cost end) as [2],
sum(case when M.Month = 3 then C.Cost end) as [3],
sum(case when M.Month = 4 then C.Cost end) as [4],
sum(case when M.Month = 5 then C.Cost end) as [5],
sum(case when M.Month = 6 then C.Cost end) as [5],
sum(case when M.Month = 7 then C.Cost end) as [7],
sum(case when M.Month = 8 then C.Cost end) as [8],
sum(case when M.Month = 9 then C.Cost end) as [9],
sum(case when M.Month = 10 then C.Cost end) as [10],
sum(case when M.Month = 11 then C.Cost end) as [11],
sum(case when M.Month = 12 then C.Cost end) as [12]
from EntryCost as C
left outer join EntryMonth as M on M.EntryID = C.EntryID
left outer join EntryDim1 as D1 on D1.EntryID = C.EntryID
left outer join EntryDim2 as D2 on D2.EntryID = C.EntryID
group by D1.Dim1, D2.Dim2
好還我在想什麼,但不確定,如果我錯過了什麼,即時通訊不熟練SQL。我會讓這個問題開放一段時間讓其他人蔘與進來。 – CodeMonkey
@Jepa我會說讓我們等待其他答案。也可以在sum中使用子查詢(因爲6NF),但我不認爲這是更好的方法 –