Vip*_*ain 16 sql t-sql sql-server ms-access pivot
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];
Run Code Online (Sandbox Code Playgroud)
需要为sql server转换此查询
我已阅读所有其他帖子但无法将其转换为相同的内容
Mah*_*mal 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;
Run Code Online (Sandbox Code Playgroud)
例如,这会给你:
| DESCRIPTION | PERIOD1 | PERIOD2 | PERIOD3 |
---------------------------------------------
| D1 | 10 | 0 | 20 |
| D2 | 100 | 1000 | 0 |
| D3 | 50 | 10 | 2 |
Run Code Online (Sandbox Code Playgroud)
请注意,使用MS SQL Server PIVOT表运算符时,必须输入已旋转列的值.但是,在MS Access中,这是TRANSFORM使用PIVOTdo 的工作,它动态获取pivoted列的值.在这种情况下,您必须使用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);
Run Code Online (Sandbox Code Playgroud)
这应该会给你相同的结果:
| DESCRIPTION | PERIOD1 | PERIOD2 | PERIOD3 |
---------------------------------------------
| D1 | 10 | 0 | 20 |
| D2 | 100 | 1000 | 0 |
| D3 | 50 | 10 | 2 |
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
35646 次 |
| 最近记录: |