【问题标题】:Assign Column Name for Simple Coalesce Statement为简单合并语句分配列名
【发布时间】:2017-07-06 00:29:45
【问题描述】:

在尝试创建自 _____ 以来创建的所有 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”的列名?

【问题讨论】:

    标签: coalesce columnname


    【解决方案1】:

    就目前的查询而言,您正在为表 BoList 指定别名“ID”而不是列。由于您将值选择到变量中,因此没有输出。你可以这样做......

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

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

    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
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-08-13
      • 2021-11-16
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-12-11
      • 1970-01-01
      • 2017-12-15
      相关资源
      最近更新 更多