0

我有以下格式的sql表

   deal_key     std_industry_name            balance
   823155199    CORP -: Aerospace & Defense 10169652.43
   823155199    CORP -: Automotive          10155993.82
   823155199    CORP -: Beverage             14779701.43
   823155199    CORP -: Capital Equipment   15150957.89
   823155199    CORP -: Chemicals           14438116.97
   823155199    CORP -: Construction        4901198.24
   823155199    CORP -: Consumer goods       9647987.3

我需要转置表格,因为我正在桌子上做一个枢轴

通过以下查询,我得到了带有一些错误的 xml 输出,因为行业列在其数据中包含空格和以下字符“:”。

SQL Server 中是否有一种方法可以根据表中的数据对列进行透视,但仍为列名提供别名,或者是否有任何其他方法可以避免此问题

  DECLARE @query VARCHAR(4000)
DECLARE @years VARCHAR(2000)
SELECT  @years = STUFF(( SELECT DISTINCT
                        '],[' + ltrim((std_industry_name))
                        FROM    [cs].[ma_deal_vintage_industry_statistics]
                        FOR XML PATH('')
                        ), 1, 2, '') + ']'

SET @query =
'SELECT * FROM
(
    SELECT deal_key, std_industry_name,balance
    FROM [cs].[ma_deal_vintage_industry_statistics]
    where deal_key =''823155199''
)t
PIVOT (SUM(balance) FOR std_industry_name
IN ('+@years+')) AS pvt for xml auto'

EXECUTE (@query)
4

1 回答 1

0

看起来像在旋转后:的列标题是失败的原因。CORP -: Aerospace & Defensefor Xml auto

替换:透视源查询和列列表。尝试这个。

   DECLARE @query VARCHAR(4000)
DECLARE @years VARCHAR(2000)
SELECT  @years = STUFF(( SELECT DISTINCT
                        '],[' + ltrim((replace(std_industry_name,':','')))
                        FROM    [cs].[ma_deal_vintage_industry_statistics]
                        FOR XML PATH('')
                        ), 1, 2, '') + ']'

SET @query =
'SELECT * FROM
(
    SELECT deal_key, replace(std_industry_name,'':'','''') std_industry_name,balance
    FROM [cs].[ma_deal_vintage_industry_statistics]
    where deal_key =''823155199''
)t
PIVOT (SUM(balance) FOR std_industry_name
IN ('+@years+')) AS pvt for xml auto'

EXECUTE (@query)
于 2015-01-09T07:41:55.593 回答