使用数据透视/转置的 SQL Server

Posted

技术标签:

【中文标题】使用数据透视/转置的 SQL Server【英文标题】:SQL Server using pivot/transpose 【发布时间】:2021-12-17 07:41:10 【问题描述】:

我需要转置/转置一个问题并寻找最好的方法来做到这一点:

原文:

ID accountno question answer
1 111 How old are you? 15
2 111 What is your favorite color? blue

最终结果:

ID accountno How old are you? What is your favorite color?
1 111 15 blue

这是我的尝试:

--I only did the first question to see if it would work
select [ID],[accountno], [How old are you?]
from 
(select ID,accountno,question,answer
from table
PIVOT 
(max(answer)
For
question in ([How old are you?])

【问题讨论】:

您不能将任意值转置为列名。此外,您可能不需要在 SQL 中进行透视(因为它是 表示层关注点,而不是 数据关注点。为什么要以 SQL 为中心? 我不明白问的是什么问题 - 你能添加一些澄清的上下文吗?您尝试的结果是什么,这与您的期望或想要的有什么不同? 出于好奇,您期望 5 个问题或 50 个问题的结果是什么? 不到10个问题。它采用向机构提交报告所需的格式。 @mfm5105 然后使用您的报告引擎转置表格,而不是 SQL。 【参考方案1】:

你已经很接近了。下面一起来看看吧

Select *
 From  (
        Select accountno
              ,question
              ,answer
         From YourTable
       ) src 
 Pivot ( max(answer) for question in ( [How old are you?]
                                      ,[What is your favorite color?]
                                     ) ) pvt

结果

【讨论】:

如此接近!现在我收到此错误:Pivot 列必须具有可比性。 “name”列的类型为“text”,不可比较。 @mfm5105 Goodness TEXT 已贬值多年。转换为 varchar 甚至 nvarchar

以上是关于使用数据透视/转置的 SQL Server的主要内容,如果未能解决你的问题,请参考以下文章

转置列或反透视 SQL 查询

如何在不使用数据透视的情况下将行转换或转置为 SQL 中的列?

如何转置 Excel 数据透视表

如何转置/透视 SQL 表

是否可以使用 SQL Server 使用相同的数据透视列进行多个数据透视

如何在不使用数据透视和反透视的情况下在 SQL Server 中水平显示数据?