TRANSFORM Avg(CASE WHEN [temp].[sumUnits] > 0
THEN [temp].[SumAvgRent] / [temp].[sumUnits]
ELSE 0
END) AS Expr1
SELECT [temp].[Description]
FROM [temp]
GROUP BY [temp].[Description]
PIVOT [temp].[Period];
需要为sql server转换此查询
我已阅读所有其他帖子,但无法将其转换为相同的
答案 0 :(得分:19)
以下是使用PIVOT
表运算符的等效版本:
SELECT *
FROM
(
SELECT
CASE
WHEN sumUnits > 0
THEN SumAvgRent / sumUnits ELSE 0
END AS Expr1,
Description,
Period
FROM temp
) t
PIVOT
(
AVG(Expr1)
FOR Period IN(Period1, Period2, Period3)
) p;
例如,这会给你:
| DESCRIPTION | PERIOD1 | PERIOD2 | PERIOD3 |
---------------------------------------------
| D1 | 10 | 0 | 20 |
| D2 | 100 | 1000 | 0 |
| D3 | 50 | 10 | 2 |
请注意使用MS SQL Server PIVOT
表运算符时,必须输入pivoted列的值。但是,在MS Access中,这是TRANSFORM
PIVOT
所做的工作,它动态获取旋转列的值。在这种情况下,您必须使用PIVOT
运算符动态执行此操作,如下所示:
DECLARE @cols AS NVARCHAR(MAX);
DECLARE @query AS NVARCHAR(MAX);
SELECT @cols = STUFF((SELECT distinct
',' +
QUOTENAME(Period)
FROM temp
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'');
SET @query = ' SELECT Description, ' + @cols + '
FROM
(
SELECT
CASE
WHEN sumUnits > 0
THEN SumAvgRent / sumUnits ELSE 0
END AS Expr1,
Description,
Period
FROM temp
) t
PIVOT
(
AVG(Expr1)
FOR Period IN( ' + @cols + ')
) p ';
Execute(@query);
这应该会给你相同的结果:
| DESCRIPTION | PERIOD1 | PERIOD2 | PERIOD3 |
---------------------------------------------
| D1 | 10 | 0 | 20 |
| D2 | 100 | 1000 | 0 |
| D3 | 50 | 10 | 2 |
答案 1 :(得分:-2)
TRANSFORM SUM(s2+s1)
SELECT PlanoContas.Conta AS Conta,
SPACE(LEN(PlanoContas.Conta)/2) + PlanoContas.Extenso AS Extenso,
PlanoContas.Tipo,SUM(s2+s1) AS [01/04/14]
FROM PlanoContas
INNER JOIN TEMP ON
PlanoContas.Conta=LEFT(Temp.Conta,LEN(PlanoContas.Conta))
WHERE LEN(PlanoContas.Conta)<=16 AND (s1<>0 OR s2<>0)
GROUP BY PlanoContas.Conta,Extenso,Tipo
ORDER BY PlanoContas.Conta PIVOT Filial