110_Power Pivot特殊结算日期及财年日期
博客:www.jiaopengzi.com
1、背景
前几天看到群里有朋友在搞特殊结算日期,主要不是按照正常日期里的整月,按照比如:上月21号至本月20号作为结算周期,由于这样的结算日期,无法使用pp里面的时间智能函数。
pp内置了很多时间智能函数,但是都无法满足需求,dax只要你创建上下文即可满足业务需求,今天就简单写个这样的度量值。
2、数据源
calendar表
2017/1/1-2018/12/31
fact表
2017/1/1-2018/12/31的随机value

关系建立

3、上DAX
total
total:=SUM('fact'[value])
ytd_1231
按照每年12月31号为结算年末的ytd,注意观察datesytd第二参数:"12-31"
ytd_1231:=CALCULATE('fact'[total],DATESYTD('calendar'[date],"12-31"))
ytd_0630
按照每年6月30号为结算年末的ytd,注意观察datesytd第二参数:"06-30"
ytd_0630:=CALCULATE('fact'[total],DATESYTD('calendar'[date],"06-30"))
mtd
按照正常整月的mtd
mtd:=CALCULATE('fact'[total],DATESMTD('calendar'[date]))
mtd2
1、按照结算周期(上月21日-本月20日,其中D是参数可以更改为自己需求)的mtd,可以看月维度及天维度;
2、考虑闰年2月29天因素
3、由于本案例中只存在2017年以后数据,2017年1月mtd即是1月1日-1月20日之间
mtd2:=
VAR D = 20//D设置为参数,D的范围应该在(1,28)
VAR MP =
COUNTROWS ( PREVIOUSMONTH ( 'calendar'[date] ) )
VAR MSD =
STARTOFMONTH ( 'calendar'[date] )
VAR N =
SWITCH (
TRUE (),
MP = 31, D - 31,
MP = 30, D - 30,
MP = 29, D - 29,
MP = 28, D - 28
)
VAR SD =
IF (
ISFILTERED ( 'calendar'[date] ),
IF (
DAY ( MAX ( 'calendar'[date] ) ) <= D,
DATEADD ( MSD, N, DAY ),
DATEADD ( MSD, D, DAY )
),
DATEADD ( MSD, N, DAY )
)
VAR ED =
IF (
ISFILTERED ( 'calendar'[date] ),
MAX ( 'calendar'[date] ),
DATEADD ( MSD, D - 1, DAY )
)
VAR T =
DATESBETWEEN ( 'calendar'[date], SD, ED )
RETURN
CALCULATE ( 'fact'[total], T )
结果图


请关注
1、mtd中2017年1月(1月1日-1月31日),即蓝色单元格;
2、mtd2中2017年1月(1月1日-1月20日),即黄色单元格;
3、mtd2中2017年2月(1月21日-2月20日),即橙色单元格(颜色如果不是橙色也暂且叫做橙色吧);
4、2017年6月中ytd_1231、ytd_0630都是相等,即红色字体单元格;
5、2017年7月中ytd_1231、ytd_0630不相等,即
绿色单元格:datesytd第二参数中,ytd_1231按照12月31日为结算年末,
红色单元格:datesytd第二参数中,ytd_0630按照6月30日为结算年末。
4、总结
1、好像没啥总结的;
2、datesytd注意第二参数的使用,主要是结算或者财年使用;
3、特殊结算周期,根据业务特点创建DAX上下文即可;
by 焦棚子
110_Power Pivot特殊结算日期及财年日期的更多相关文章
- 一起学微软Power BI系列-使用技巧(5)自定义PowerBI时间日期表
1.日期函数表作用 经常使用Excel或者PowerBI,Power Pivot做报表,时间日期是一个重要的纬度,加上做一些钻取,时间日期函数表不可避免.所以今天就给大家分享一个自定义的做日期表的方法 ...
- [MSSQL]採用pivot函数实现动态行转列
环境要求:2005+ 在日常需求中常常会有行转列的事情需求处理.假设不是动态的行,那么我们能够採取case when 罗列处理. 在sql 2005曾经处理动态行或列的时候,通常採用拼接字符串的方法处 ...
- Sql2008的行列转换之行转列
今天在工作的时候遇到了行列转换的问题,记得去年有一段时间经常写,但是许久不用已经记不太得了.好记性不如烂笔头,忙完之后赶紧记录一下. 关键字:PIVOT(行转列),UNPIVOT(列转行) 先说说 P ...
- Oracle根据【日期】组,其他条件根据PIVOT行转列。使每个日期条件关联的其他数据只有一行。
select OPER_TIME, MICROPAY, REFUND from ( select trunc(oper_time) oper_time, class_name, sum(total_f ...
- 122_Power Pivot&Power BI不连续日期的日环比
博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 这两天有朋友在交流,dax中使用时间智能函数写日环比,一个 dateadd 就可以了.但是有些业务不是每天都连续 ...
- 如何用Pivot实现行列转换
在Oracle中,如果要实现行列转换,较为常见的是用DECODE和CASE语句.对于简单的行列转行,DECODE和CASE语句尚能应付.在逻辑比较复杂,分组聚合较多的场景中,DECODE和CASE语句 ...
- 在Sqlserver下巧用行列转换日期的数据统计
在Sqlserver下巧用行列转换日期的数据统计 前言 在SQLSERVER 中有很多统计函数的基础语法,有使用Group By 或 partition by 后配合Sum,Count(*) 等用法. ...
- 中等难度SQL语句(存储过程,分页,拼接字段、游标,日期类型转换,动态行转列,视图)汇总
一.创建存储过程 if Exists(select name from sysobjects where NAME = 'sp1LoginUser' and type='P')drop procedu ...
- 每日学习心得:SQL查询表的行列转换/小计/统计(with rollup,with cube,pivot解析)
2013-8-20 1. SQL查询表的行列转换/小计/统计(with rollup,with cube,pivot解析) 在实际的项目开发中有很多项目都会有报表模块,今天就通过一个小的SQL ...
随机推荐
- C++ | 虚函数产生条件
虚函数产生的条件 能否成为虚函数主要有以下两种判断依据,如果以下两种条件均满足,则具有成为虚函数的条件. 1.虚函数机制为动多态提供支持,而虚函数表中存放着虚函数的地址.因此虚函数必须是可以取地址的函 ...
- web前端教程《每日一题》(1-99)完结
第1期(2016年4月6日): (1)js中关闭当前窗口的方法是:window.close(); 第2期(2016年4月7日): (1)js中使字符串中的字符变为小写的方法是:toLowerCase方 ...
- 来扯点ionic3[3] 页面的生命周期事件,也就是凡间所说的钩子
首先要做一个诚挚的道歉,作为大四狗,因为升学的事情,断更两个月,所以要感谢各位仁慈的读者没有脱粉(好像也就50个粉丝).这一节,我们延续上一节制作的页面,来讨论声明周期钩子的事情. 以我的经验来看,多 ...
- hive从入门到放弃(四)——分区与分桶
今天讲讲分区表和分桶表,前面的文章还没看的可以点击链接: hive从入门到放弃(一)--初识hive hive从入门到放弃(二)--DDL数据定义 hive从入门到放弃(三)--DML数据操作 分区 ...
- 记住用户名和登录密码+虚拟机没有root权限解决办法
今日所学: 记住用户名和登录密码 用adb查看保存文件内容 如何使用adb 如何安装adb-百度经验 遇到的问题: 用adb查看文件时,没有权限访问data文件 出现原因:google play虚拟机 ...
- Java中使用最频繁及最通用的Java工具类
在Java中,工具类定义了一组公共方法,Java中使用最频繁及最通用的Java工具类. 一. org.apache.commons.io.IOUtils closeQuietly:关闭一个IO流.so ...
- CSS简单样式练习(七)
运行效果: 源代码: 1 <!DOCTYPE html> 2 <html lang="zh"> 3 <head> 4 <meta char ...
- [ Shell ] 通过 Shell 脚本导出 GDSII/OASIS 文件
https://www.cnblogs.com/yeungchie/ 常见的集成电路版图数据库文件格式有 GDSII 和 OASIS,virtuoso 提供了下面两个工具用来在 Shell 中导出版图 ...
- linux添加磁盘及分区挂载
磁盘管理 1.为什么要添加磁盘 随着系统的使用,磁盘的内容会越来越少,所以这时要添加磁盘增加空间 Linux系统中磁盘管理就是将硬盘通过挂载的方式挂载到linux文件系统中. 2.系统添加磁盘并分区 ...
- 五分钟搭建博客系统 OK?
前言: 请各大网友尊重本人原创知识分享,谨记本人博客:南国以南i 概要: 通过 Docker Compose 在使用Docker容器构建的隔离环境中轻松运行 WordPress.在开始之前,请确保已安 ...