SQL Server 2008 R2: Concatenate alias name with column value(SQL Server 2008 R2:将别名与列值连接起来)
问题描述
我有 Product 表,其中包含 QtyID、Qty 和 Year_ID 列.我还有一个表 tbl_Years 带有 ID 和 Year.
I have Product table with columns QtyID, Qty and Year_ID. I also have a table tbl_Years with ID and Year.
我有一个简单的 SELECT 语句,其中 SUM 计算 Qty:
I have a simple SELECT statement with SUM calculation of 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.
I want to define an alias name of Sum_of_year_2016 for the SUM(Qty) value.
注意:应从 tbl_Years 表中获取年份.
Note: the year should be fetched from the tbl_Years table.
我的尝试:
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获取自定义别名:
You need to use dynamic SQL to get custom alias:
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 2008 R2:将别名与列值连接起来的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:SQL Server 2008 R2:将别名与列值连接起来
基础教程推荐
- 需要 MySQL 5.1 中的抽象触发器来更新审计日志 2021-01-01
- 将 SQL Server DateTime 列迁移到 DateTimeOffset 2021-01-01
- 是否可以执行按位分组功能? 2021-01-01
- SSMS 中的权限问题:“对象 'extended_properties'、数据库 'mssqlsystem_resource'、... 错误 229)上的 SELECT 权限被拒绝" 2022-01-01
- SQL:使用来自具有相同列名的两个表中的数据... 2021-01-01
- 如何使用 mysql.connector 禁用查询缓存 2022-01-01
- 无法解决整理冲突 2021-01-01
- 在 SQL 中连接多个表 2021-01-01
- SQL 效率:WHERE IN 子查询 vs. JOIN 然后 GROUP 2021-01-01
- SQL Server 实例在登录协商期间返回无效或不受支持的协议版本 2021-01-01
