工作技巧 | 展示某指定年月之前 12 个月份的销售额

本文介绍了如何在Power BI中创建一个动态表,展示切片器选择的指定年月之前12个月的销售额。通过构建数据模型、度量值计算以及解决总计行问题,实现了对销售额的正确显示和总计。关键步骤包括计算开始日期、筛选上下文和应用总计条件。
摘要由CSDN通过智能技术生成


本期重点:
1.使用度量值计算得到某个指定年月之前的十二个月份
2.解决总计行问题,在总计行计算上述区间内的销售总额

小伙伴们好啊,日常工作场景中我们总会遇到一些比较有难(qi)度(pa)的需求。今天就和大家分享一个脑洞大开的案例。先看效果图:

当我们在年月切片器中选中某个月的时候,左侧的table会自动计算出从当前切片器的年月向前移动12个月的各自月份销售额。
该案例的难点在于:
如何通过给定的切片器中的年月,在table中拖拽出前12个月的年月信息
如何在总计行正确的显示前12个月销售总额
接下来就随我一起玩转这个案例吧!

第一步:构建数据模型

如下图示:
file

在我们的模型中一共有三张表:日期表,销售数据和参数表(辅助日期表)。日期表和销售数据构成一对多关系。参数表是由日期表复制出来的,和其他两个表之间不建立关系。其中,参数表和日期表需放置到画布中的字段都按照各自的序号做了按列排序。还需要指明的是,在画布中,年月筛选器用的是参数表的年月字段。而table中的年月字段则是来自于真正的日期表

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,那我们假设有一个销售表 sales,其中包含以下字段: - id:销售记录的唯一标识符 - product_id:商品的唯一标识符 - sale_date:销售日期,格式为 YYYY-MM-DD - sale_amount:销售金额 我们可以使用如下 SQL 语句来查询每个商品的销售额同环比: ```sql SELECT DATE_FORMAT(s1.sale_date, '%Y-%m') AS month, SUM(s1.sale_amount) AS current_month_sales, SUM(s2.sale_amount) AS last_month_sales, SUM(s1.sale_amount) / SUM(s2.sale_amount) - 1 AS mom_growth_rate, SUM(s1.sale_amount) / SUM(s3.sale_amount) - 1 AS yoy_growth_rate FROM sales s1 LEFT JOIN sales s2 ON DATE_FORMAT(s1.sale_date, '%Y-%m') = DATE_FORMAT(DATE_SUB(s2.sale_date, INTERVAL 1 MONTH), '%Y-%m') AND s1.product_id = s2.product_id LEFT JOIN sales s3 ON DATE_FORMAT(s1.sale_date, '%Y-%m') = DATE_FORMAT(DATE_SUB(s3.sale_date, INTERVAL 1 YEAR), '%Y-%m') AND s1.product_id = s3.product_id GROUP BY DATE_FORMAT(s1.sale_date, '%Y-%m') ``` 这个 SQL 语句使用了三个子查询,分别对应当前、上和去同期的销售数据。通过 LEFT JOIN 连接这三个子查询,我们可以得到每个销售额、上销售额、去同期销售额,以及同环比增长率。其中,同比增长率计算方式为 `(当前销售额 / 去同期销售额) - 1`,环比增长率计算方式为 `(当前销售额 / 上销售额) - 1`。最后,我们使用 DATE_FORMAT 函数将销售日期格式化为,然后按月份分组,即可得到每个的同环比销售数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值