为简单合并语句分配列名

Assign Column Name for Simple Coalesce Statement

在尝试创建自 _____ 以来创建的所有 ID 的列表时,我能够从以下内容中获得我想要的结果:

DECLARE @BoID varchar(max)

SELECT @BoID = COALESCE(@BoID + ', ', '') + 
   CAST(ApplicationID AS varchar(10)) 
FROM BoList as "ID"
WHERE CreatedDate > '2017-07-01 18:14:09.210' 

但是,我在为上述语句建立列名时遇到了问题。 as "ID" 需要位于何处才能为上述结果提供列名称 "ID"?

按照现在的查询,您给 table BoList 一个别名 "ID" 而不是列。由于您将值选择到变量中,因此没有输出。你可以这样做...

SELECT COALESCE(@BoID + ', ', '') + 
   CAST(ApplicationID AS varchar(10)) as "ID"
FROM BoList 
WHERE CreatedDate > '2017-07-01 18:14:09.210'

或者,如果您确实需要稍后将变量中的值作为另一个查询的一部分存储到 return...

DECLARE @BoID varchar(max)

SELECT @BoID = COALESCE(@BoID + ', ', '') + 
   CAST(ApplicationID AS varchar(10)) 
FROM BoList
WHERE CreatedDate > '2017-07-01 18:14:09.210' 

SELECT @BoID AS "ID", other columns... FROM whatever