每个结果多行的 SQL Pivot
Posted
技术标签:
【中文标题】每个结果多行的 SQL Pivot【英文标题】:SQL Pivot with multiple lines per result 【发布时间】:2021-03-15 10:50:44 【问题描述】:我正在尝试了解如何使用 Advantage Database Server 调整日期。
我有以下代码,它将(使用 CASE)我们的月度销售数据:
SELECT YEAR(date) as MyYear
, SUM(CASE WHEN MONTH(date) = 1 THEN value END) jan_revenue
, SUM(CASE WHEN MONTH(date) = 1 THEN value - (qty*ekp/pe) END) jan_margin
, SUM(CASE WHEN MONTH(date) = 2 THEN value END) feb_revenue
, SUM(CASE WHEN MONTH(date) = 2 THEN value - (qty*ekp/pe) END) feb_margin
, SUM(CASE WHEN MONTH(date) = 3 THEN value END) mar_revenue
, SUM(CASE WHEN MONTH(date) = 3 THEN value - (qty*ekp/pe) END) mar_margin
FROM (SELECT DAB020.*
, EXTRACT(YEAR FROM date) year
, EXTRACT(MONTH FROM date) month
FROM "DAB020.ADT" DAB020
where buart = 'A' and auf_kumsta = 'J' and date >= '2021-01-01'
) mysalesdata
GROUP BY YEAR(date)
这会产生如下所示的结果:
MyYear jan_revenue jan_margin feb_revenue jan_margin_1 mar_revenue jan_margin_2
2021 23123414 12312323 4554535 545345 435345 123123
我真正想要的是让收入和利润处于不同的线上:
MyYear TYPE jan Feb Mar
2021 Revenue 23123414 12312323 4554535
2021 Margin 545345 435345 123123
(数字是假的,但你明白了)
我该怎么做?我确信 CASE 和 Grouping 的组合是解决方案,但我无法解决。
(编辑:据我所知,ADS 中没有枢轴功能)
【问题讨论】:
【参考方案1】:反透视数据以获得不同行的利润和收入。然后像现在这样聚合:
SELECT YEAR(date) as MyYear, type,
SUM(CASE WHEN MONTH(date) = 1 THEN value END) as jan,
SUM(CASE WHEN MONTH(date) = 2 THEN value END) as feb,
SUM(CASE WHEN MONTH(date) = 3 THEN value END) as mar
FROM (SELECT DAB020.*
FROM (SELECT date, 'revenue' as type, value, buart, aufkumsta
FROM "DAB020.ADT" UNION ALL
SELECT date, 'margin' as type, value - (qty*ekp/pe), buart, aufkumsta
FROM "DAB020.ADT"
) DAB020
WHERE buart = 'A' AND auf_kumsta = 'J' AND
date >= '2021-01-01'
) mysalesdata
GROUP BY YEAR(date)
【讨论】:
谢谢,它有效。非常有用...要解码并尽可能多地重复使用! 如果可以的话,再问一个问题:如何在结果中添加计算字段(边距 %) @egg 。 . .您应该针对保证金百分比提出另一个问题,并确保显示结果应该是什么样子。以上是关于每个结果多行的 SQL Pivot的主要内容,如果未能解决你的问题,请参考以下文章
SQL 中的 Pivot 语法错误,为啥我得到不正确的结果?