我有 Product
表,其中包含 QtyID
、Qty
和 Year_ID
列。我还有一个带有 ID
和 Year
的表 tbl_Years
。
我有一个简单的 SELECT
语句,其中包含 SUM
计算 Qty
:
SELECT
SUM(Qty) AS /*Sum_of_year_2016*/
FROM
Product p
INNER JOIN
tbl_Years ty ON p.Year_ID = ty.Year_ID
WHERE
ty.Year_ID = 6;
我想为 SUM(Qty)
值定义别名 Sum_of_year_2016
。
注意:年份应从 tbl_Years
表中获取。
我的尝试:
SELECT
SUM(Qty) AS 'Sum_of_year_' + ty.Year
FROM
Product p
INNER JOIN
tbl_Years ty ON p.Year_ID = ty.Year_ID
WHERE
ty.Year_ID = 6;
但是我收到错误:
Syntax error; incorrect syntax near '+'.
最佳答案
您需要使用动态SQL来获取自定义别名:
DECLARE @year NVARCHAR(4) = (SELECT TOP 1 Year FROM tbl_Years WHERE Year_id=6);
DECLARE @sql NVARCHAR(MAX) =
'SELECT
SUM(Qty) AS ' + QUOTENAME('Sum_of_year_' + @year) +
' FROM Product p
INNER JOIN tbl_Years ty
ON p.Year_ID = ty.Year_ID
Where ty.Year_ID = 6;';
EXEC sp_executesql @sql;
关于sql-server - SQL Server 2008 R2 : Concatenate alias name with column value,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45706630/