首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL中的提升力计算

SQL中的提升力计算
EN

Stack Overflow用户
提问于 2020-05-04 23:40:19
回答 1查看 84关注 0票数 0

我有以下数据聚合表:

代码语言:javascript
复制
group_name | period | sum(spend) | count(store_id)
A | pre | 100 | 5
A | current | 150 | 4
B | pre | 80 | 10
B | current | 50 | 10

我想用SQL把数据转换成如下形式(其中spend_per_store_id是sum(花费)/count(Store_id),uplift是current /pre之间的比率):

代码语言:javascript
复制
uplift | A | B | A compared to B current | A compared to B pre
sum(spend) | current/pre | current/pre | current/current | pre/pre
spend_per_store_id | current/pre | current/pre | current/current | pre/pre

我有点纠结于如何在不使用一大堆case语句和联合all的情况下做到这一点。

编辑:预期输出示例(提供计算而不是实际数字)

代码语言:javascript
复制
uplift | A | B | A compared to B current | A compared to B pre
sum(spend) | 150/100 | 50/80 | 150/50 | 150/80
EN

回答 1

Stack Overflow用户

发布于 2020-05-04 23:45:44

将行转置为列的操作是一个透视,有一些简单的、复杂的或专有的方法来进行透视。但对于您来说,最简单的方法可能是使用连接,因为您似乎只有一组数据用于current和pre,您想要将它们关联在一起:

代码语言:javascript
复制
SELECT ..., cur.sumspend / pre.sumspend as percent_spend_change 
FROM

  (SELECT * FROM table WHERE period = 'pre') pre
  INNER JOIN
  (SELECT * FROM table WHERE period = 'current') cur
  ON pre.group_name = cur.group_name

现在,将第一个SELECT ...替换为您想要知道的所有内容的计算。例如,uplift是cur.sumspend / pre.sumspendcur.sumspend - pre.sumspend (取决于您如何定义"uplift"/as百分比或原始值),依此类推。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61596063

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档