数据可视化之DAX篇(二十五)PowerBI常用的度量值:累计至今

摘要:
我们要计算的是从开始到任何日期的累计销售额。从历史到现在的累计收入=计算(SUM(“订单表”[销售]),=MAX(“日期表”[日期])),然后查看矩阵中的结果。该度量的关键是使用MAX函数获取当前上下文的日期。事实上,如果大于最后一个订单日期,则无需计算。最大订单日期=MAXX(ALL(“订单表”),“订单表’[订单日期]),然后将判断条件添加到历史累积中。

https://zhuanlan.zhihu.com/p/64999937

经常碰到本年至今、本月至今的数据计算,其实还有一类计算是,从历史最早日期至今的累计计算,比如从开业到现在总共卖出了多少件商品,累计实现了多少销售额等。

本年累计称为YTD,历史至今的累计是不是可以称为HTD呢:) ;这样的时间段很可能是跨年的,所以时间智能函数并不适用,不过不用时间智能函数依然可以很简单的进行计算。

模拟数据如下:

 

数据可视化之DAX篇(二十五)PowerBI常用的度量值:累计至今第1张

只是计算一个整体累计销售额很简单,我们想要计算的是从最初到任意一个日期的累计销售额,为了能一次计算出各种粒度的历史至今,可以先构造一个日期表并建立关系。(参考:玩PowerBI必备的日期表制作方式汇总

然后写个度量值,

历史至今 累计收入 =

CALCULATE(

SUM('订单表'[销售额]),

FILTER(

ALL('日期表'),

'日期表'[日期]<=MAX('日期表'[日期])))

 

然后在矩阵中看看结果,

 

数据可视化之DAX篇(二十五)PowerBI常用的度量值:累计至今第2张

 

结果正是历史所有订单的累计销售额,这个度量值的关键是用MAX函数获取当前上下文的日期,然后返回小于等于当前日期的所有销售额的合计。

这个度量值写法有一个问题,就是它把日期表中所有的日期都计算了一遍,其实大于最后一个订单日期的无须计算,因为结果并不会发生变化。

为了解决这个问题,可以先把最后一个订单日期找出来:

订单最大日期 = MAXX(ALL('订单表'),'订单表'[订单日期])

然后在历史累计中增加个判断条件,

历史至今 累计收入 优化 =

IF(
MIN('日期表'[日期])<=[订单最大日期],
CALCULATE(
SUM('订单表'[销售额]),
FILTER(
ALL('日期表'),
'日期表'[日期]<=MAX('日期表'[日期]))))

再来看一下结果,

 

数据可视化之DAX篇(二十五)PowerBI常用的度量值:累计至今第3张

 

正是期望的效果。

历史至今的聚合计算,不一定只是累计求和,还可以找出历史上最大的订单金额,或者历史至今的平均订单金额,这些情况只需要改一下聚合函数就行了,比如平均订单金额就是把SUM改成AVERAGE,

历史至今 平均订单订单 =

IF(
MIN('日期表'[日期])<=[订单最大日期],
CALCULATE(
AVERAGE('订单表'[销售额]),
FILTER(
ALL('日期表'),
'日期表'[日期]<=MAX('日期表'[日期]))))

最大最小订单同理,不再一一列出,结果如下:

 

数据可视化之DAX篇(二十五)PowerBI常用的度量值:累计至今第4张

免责声明:文章转载自《数据可视化之DAX篇(二十五)PowerBI常用的度量值:累计至今》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇nginx重定向Mac10.9下的libtiff编译下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

PostgreSQL中的Object Identifier(oid)数据类型

PostgreSQL在内部使用对象标识符(OID)作为各种系统表的主键。OID不会添加到用户创建的表中,除非在创建表时指定了WITH OIDS,或者启用了default_with_oids配置变量。类型oid表示对象标识符。oid还有几种别名类型:regproc,regprocedure,regoper,regoperator,regclass,regty...

试试SQLServer 2014的内存优化表

试试SQLServer 2014的内存优化表 SQL Server2014存储引擎:行存储引擎,列存储引擎,内存引擎 SQL Server 2014中的内存引擎(代号为Hekaton)将OLTP提升到了新的高度。 现在,存储引擎已整合进当前的数据库管理系统,而使用先进内存技术来支持大规模OLTP工作负载。 就算如此,要利用此新功能,数据库必须包含“内存优化...

My97日期控件My97DatePicker使用(备忘)

前言: 最近老是找不到资料,痛之又痛的情况下,决定好好将所有涉及到的东西通通做个备忘记录。 参考网址: 1、http://www.my97.net/dp/demo/index.htm 2、http://www.mysuc.com/test/My97DatePicker/#m246 使用备忘—— 日期:2010-10-30 版本:4.7 功能:两个日期文本框...

【SQL】日期型函数

1、 SYSTATE 用来返回系统当前时间 SQL> select sysdate from dual; SYSDATE ------------------- 2017-03-03 09:49:25 2、 ADD_MONTHS 语法: ADD_MONTHS(date,integer) 用于从一个日期值增加或减少一些月份 1) 返回系统时间一个月后...

【转】通用权限管理设计 之 功能权限设计

一,前言  权限管理系统的应用者应该有三种不同性质上的使用, A,使用权限 B,分配权限 C,授权权限  本文只从《使用权限》和《分配权限》这两种应用层面分析,暂时不考虑《授权权限》这种。 二,初步分析 用户和角色  说到权限管理,首先应该想到,当然要设计一个用户表,一个权限表。这样就决定了一个人有什么样的权限。 做着做着就会发现这样设计太过繁琐,如果公...

Mysql日期分组无数据查询填充0

前言 这篇文章标题不好取。。。(主要是生成连续的日期),本文关键点有:Mysql 获取指定时间段内的所有日期列表, Mysql 按照日期分组查询没有数据的日期也一并查询出来。 本文原文链接地址:http://nullpointer.pw/Mysql%E6%97%A5%E6%9C%9F%E5%88%86%E7%BB%84%E6%97%A0%E6%95%B0%...