【发布时间】: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。
标签: sql sql-server tsql pivot