对于一个带有第六种普通形式的表的简单透视示例,SQL代码是什么样的?
很多人都在谈论如何使用6NF表轻松快速地进行转换,但很难找到这样的例子。
假设我有以下表格:
Table: EntryCost
EntryId
Cost
Table: EntryMonth
EntryId
Month
Table: EntryDim1
EntryId
Dim1
Table: EntryDim2
EntryId
Dim2
如何在不使用MSSQL PIVOT或同等产品的情况下进行转换?说我希望聚合成本,一边是维度,一边是沿着列的几个月
答案 0 :(得分:0)
我认为一般方法是这样的:
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