我目前正在将数据返回到SQL存储过程中的表中。我试图将行透视成列,将列透视成行,但是我正努力做到这一点,因为我正在遵循的许多教程对此进行了布局,它们的表是不同的。
这是存储过程底部的选择:
select
(CASE WHEN [Fitter] IS NULL THEN (Select Distinct substring([First Name],1,1)+' '+[Second Name] from Fitters where [Fitter Id]=FitterId) ELSE Fitter END) AS Fitter,
sum([Install Sell]) as [Install Sell],
sum([Install Cost]) as [Install Cost],
sum([Install Cost Amt]) as Gross,
(select cast(CAST((TaxStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) as CIS,
(select cast(CAST((VatStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) as VAT,
sum([Install Cost Amt]) - (select cast(CAST((TaxStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) + (select cast(CAST((VatStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) as FittersPay,
sum([Install Cost Amt]) + (select cast(CAST((VatStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) as Datafile
from @TempTable
group by FitterId, Fitter, TaxStatus, VatStatus
这是它返回的数据:
我想让列以行为枢轴,而行以列为枢轴...
我已经在网上搜索过,并且正在努力找出答案,我想知道我是否可以在此方面获得一些帮助。
任何帮助表示赞赏。
这是通过先取消枢轴操作然后再进行枢轴操作来完成的。这是一个示例,您可以调整自己的数据:
DECLARE @t TABLE(col0 VARCHAR(20), col1 MONEY, col2 MONEY, col3 MONEY)
INSERT INTO @t VALUES
('aaaaaa', 1, 1.2, 0),
('bbbbbb', 2, 2.2, 0),
('cccccc', 3, 3.3, 100),
('dddddd', 4, 4.4, 0)
SELECT * FROM @t
SELECT * FROM @t
UNPIVOT (a FOR b IN([col1],[col2],[col3])) up
PIVOT (MAX(a) FOR col0 IN([aaaaaa],[bbbbbb],[cccccc],[dddddd])) p
输出1:
col0 col1 col2 col3
aaaaaa 1.00 1.20 0.00
bbbbbb 2.00 2.20 0.00
cccccc 3.00 3.30 100.00
dddddd 4.00 4.40 0.00
输出2:
b aaaaaa bbbbbb cccccc dddddd
col1 1.00 2.00 3.00 4.00
col2 1.20 2.20 3.30 4.40
col3 0.00 0.00 100.00 0.00
这取决于您的数据类型,但是您可能需要动态地进行操作。该站点上有很多示例。只需搜索dynamic pivoting
。
编辑:
像这样的东西:
select * from (
select
(CASE WHEN [Fitter] IS NULL THEN (Select Distinct substring([First Name],1,1)+' '+[Second Name] from Fitters where [Fitter Id]=FitterId) ELSE Fitter END) AS Fitter,
sum([Install Sell]) as [Install Sell],
sum([Install Cost]) as [Install Cost],
sum([Install Cost Amt]) as Gross,
(select cast(CAST((TaxStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) as CIS,
(select cast(CAST((VatStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) as VAT,
sum([Install Cost Amt]) - (select cast(CAST((TaxStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) + (select cast(CAST((VatStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) as FittersPay,
sum([Install Cost Amt]) + (select cast(CAST((VatStatus/100 * sum([Install Cost Amt])) as decimal(18,5)) as float)) as Datafile
from @TempTable
group by FitterId, Fitter, TaxStatus, VatStatus) t
UNPIVOT (a FOR b IN([Install Sell],[Install Cost],[Gross]/*,...*/)) up
PIVOT (MAX(a) FOR Fitter IN([D Page],[J Hopley]/*,...*/)) p
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句