如何将两列堆叠为单列中的行?

时间:2019-05-21 14:59:29

标签: sql sql-server unpivot

我有一个名为'model'的表,我希望sql server代码能够达到目的。

enter image description here

我希望的输出如下,

enter image description here

任何帮助将不胜感激。

3 个答案:

答案 0 :(得分:2)

您可以尝试一下-另一种简单的方法:)

SELECT ModelA, Discount
from table1

UNION 

SELECT ModelB, Discount
from table1

答案 1 :(得分:0)

我喜欢为此目的使用terraform plan

apply

select v.model, t.discount from t cross apply (values (model1), (model2)) v(model); 是一个非常强大的构造,它实现了称为“横向连接”的东西。还有其他取消透视数据的方法,但是我取消透视是横向联接的很好的介绍。

答案 2 :(得分:0)

您需要UNION ALL

select modela as model, discount from model
union all
select modelb, discount from model