博客:www.jiaopengzi.com

焦棚子的文章目录

请点击下载附件

一背景

前面写过了一个关于进销存的案例,留一个话题就是先进先出的库存计算。

刚好有朋友提了相关这样的需求。先来看看效果。


效果图

说明:

1、按照先进先出的原则,计算库存的库龄结构,如效果图。

2、特别说明下先进先出,即先入库产品先出库,从而有了库龄。

3、工作中更多会用批次来管理,案例中没有批次,需要写出库龄结构是有些绕。

4、感谢q友阳光岁月提供数据素材。

二、数据源

1、data

原始脱敏数据,大约6万多条,其中数据是erp导出的,需要清洗。

2、维度表:品号

3、日期表

4、事实表:入库

5、事实表:出库

6、关系

7、注意

这个数据里面没有期初库存,即入库汇总即库存总和。

三、上dax

1、入库

入库:=SUM('入库'[入库数量])

2、出库

出库:=SUM('出库'[出库数量])

3、库存

库存:=IF ( '入库'[入库] - '出库'[出库] = 0, BLANK (), '入库'[入库] - '出库'[出库] )

4、库龄0_30

库龄0_30:=
VAR MIND =
FIRSTDATE ( '日期表'[日期] )
VAR X = 0
VAR Y = 30
VAR MAXD =
FIRSTDATE ( DATESINPERIOD ( '日期表'[日期], TODAY () - X, - Y, DAY ) )
VAR LD =
LASTDATE ( DATESINPERIOD ( '日期表'[日期], TODAY () - X, - Y, DAY ) )
VAR CURT =
DATESINPERIOD ( '日期表'[日期], TODAY () - X, - Y, DAY )
VAR T1 =
DATESBETWEEN ( '日期表'[日期], MIND, MAXD )
VAR T2 =
DATESBETWEEN ( '日期表'[日期], MIND, LD )
VAR KC1 =
CALCULATE ( '入库'[入库], T1 )
VAR KCN =
CALCULATE ( '入库'[入库], CURT )
VAR KCA =
CALCULATE ( '入库'[入库], T2 )
VAR CK = '出库'[出库]
VAR RS1 = KC1 - CK
VAR RS2 = KCA - CK
VAR RS =
SWITCH ( TRUE (), RS1 > 0, KCN, RS2 > 0, RS2, BLANK () )
VAR RST =
SUMX (
SUMMARIZECOLUMNS (
'品号'[品号],
'品号',
"T", SWITCH (
TRUE (),
CALCULATE ( '入库'[入库], T1 ) - '出库'[出库]
> 0, CALCULATE ( '入库'[入库], CURT ),
CALCULATE ( '入库'[入库], T2 ) - '出库'[出库]
> 0, CALCULATE ( '入库'[入库], T2 ) - '出库'[出库],
BLANK ()
)
),
[T]
)
RETURN
IF ( ISFILTERED ( '品号'[品号] ), RS, RST )

5、库龄30_60,库龄60_90,库龄90_180,库龄180_360,库龄360以上几个逻辑都是一样,只是参数X,Y不一样;如下图。

6、库龄360以上

由于本案例数据只有2018年以后的数据,所以Y参数(见下图)需要特殊处理下

库龄360以上:=
VAR MIND =
FIRSTDATE ( '日期表'[日期] )
VAR X = 360
VAR Y =
DATEDIFF ( MIND, TODAY () - 360, DAY )
VAR MAXD =
FIRSTDATE ( DATESINPERIOD ( '日期表'[日期], TODAY () - X, - Y, DAY ) )
VAR LD =
LASTDATE ( DATESINPERIOD ( '日期表'[日期], TODAY () - X, - Y, DAY ) )
VAR CURT =
DATESINPERIOD ( '日期表'[日期], TODAY () - X, - Y, DAY )
VAR T1 =
DATESBETWEEN ( '日期表'[日期], MIND, MAXD )
VAR T2 =
DATESBETWEEN ( '日期表'[日期], MIND, LD )
VAR KC1 =
CALCULATE ( '入库'[入库], T1 )
VAR KCN =
CALCULATE ( '入库'[入库], CURT )
VAR KCA =
CALCULATE ( '入库'[入库], T2 )
VAR CK = '出库'[出库]
VAR RS1 = KC1 - CK
VAR RS2 = KCA - CK
VAR RS =
SWITCH ( TRUE (), RS1 > 0, KCN, RS2 > 0, RS2, BLANK () )
VAR RST =
SUMX (
SUMMARIZECOLUMNS (
'品号'[品号],
'品号',
"T", SWITCH (
TRUE (),
CALCULATE ( '入库'[入库], T1 ) - '出库'[出库]
> 0, CALCULATE ( '入库'[入库], CURT ),
CALCULATE ( '入库'[入库], T2 ) - '出库'[出库]
> 0, CALCULATE ( '入库'[入库], T2 ) - '出库'[出库],
BLANK ()
)
),
[T]
)
RETURN
IF ( ISFILTERED ( '品号'[品号] ), RS, RST )

库龄360以上,参数Y特殊处理。

四、总结

1、老样子业务逻辑转换dax上下文;

2、案例中先进先出运用的是累计计算的思路;

3、案例中总计行需要单独写,使用SUMMARIZECOLUMNS(office2013之前版本请使用SUMMARIZE)聚合,搭配迭代函数SUMX计算。

SUMMARIZECOLUMNS function (DAX)

附注:


原始数据异常导致

异常数据

本来想把异常数据删掉的,后来想想就留着吧,有兴趣的朋友可以实际操作看看。

注意:

数据动态用的是today来写的,拿到附件以后,得出来的结果和截图自然不一样,如果需要验证,把电脑日期回调至2019年1月13日即可。

by 焦棚子

焦棚子的文章目录

116_Power Pivot 先进先出原则库龄库存计算相关的更多相关文章

  1. 【MM系列】SAP库龄报表逻辑理解

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]SAP库龄报表逻辑理解   第一篇 ...

  2. 【MM系列】SAP SAP库龄报表逻辑理解

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]SAP SAP库龄报表逻辑理解   ...

  3. SAP库龄表

    &---------------------------------------------------------------------* *& Report ZFIR005 *& ...

  4. 用友ERP T6技术解析(六) 库龄分析

    2.4 库存管理   2.4.1 库龄分析 介绍:库存账龄是在某时间节点,某种或某类存货的库存时间的加权平均值,跟库存周转率关系明显,库存周转率越高,库存账龄越低,可是二者又不是反比关系.不能简单把库 ...

  5. Odoo:全球第一免费开源ERP库龄表的简单实现方法(无需二开)

    问题背景 希望查看库龄超过30天的货物,该如何实现?此种简单数据查询需要二开吗? 解决方案 方法一:Stock Quant列表视图增加过滤器 <filter string="库龄超30 ...

  6. 通过IP地址和子网掩码与运算计算相关地址

    通过IP地址和子网掩码与运算计算相关地址 知道IP地址和子网掩码后可以算出 网络地址 广播地址 地址范围 本网有几台主机 例一:下面例子IP地址为192.168.100.5 子网掩码是255.255. ...

  7. 备库Seconds_Behind_Master的计算

    背景 在mysql主备环境下,主备同步过程如下,主库更新产生binlog, 备库io线程拉取主库binlog生成relay log.备库sql线程执行relay log从而保持和主库同步. 理论上主库 ...

  8. PHP用mb_string函数库处理与windows相关中文字符

    昨天想批处理以前下载的一堆文件,把文件里的关键内容用正则匹配出来,集中处理.在操作文件时遇到一个问题,就是windows操作系统中的编码问题. 我们都知道windows中(当然是中文版),文件名和文件 ...

  9. java IO选择流的原则及其与IO流相关类的关系

    1 按照用途进行分类 1.1 按照数据的来源(去向)分类 是文件:FileInputStream, FileOutputStream, FileReader, FileWriter 是byte[]:B ...

随机推荐

  1. C++ | 再探智能指针(shared_ptr 与 weak_ptr)

    上篇博客我们模拟实现了 auto_ptr 智能指针,可我们说 auto_ptr 是一种有缺陷的智能指针,并且在C++11中就已经被摈弃掉了.那么本章我们就来探索 boost库和C++11中的智能指针以 ...

  2. C语言常用字符串函数

    string.h头文件中常用的函数 C 库函数 - strcat() char *strcat(char *dest, const char *src) 把 src 所指向的字符串追加到 dest 所 ...

  3. (5) 图和表(Figure and Table) 【论文写作】

  4. 圣诞节,把网站所有的js代码都压缩成圣诞树吧。

    本文分两章节,分别讲解如何使用js2image这个库生成可以运行的圣诞树代码 和 js2image的原理. github地址:https://github.com/xinyu198736/js2ima ...

  5. Web前端初级问题—ajax登录跳转登录实现

    当我们的用户进行系统登录时,用户名和密码的验证都是后端验证的.而且,用户登录状态也是要后端设置的,查询数据库后,用户名和密码正确,则在session中存储一个uuid,每个页面需要根据登录状态判断展示 ...

  6. 小程序canvas文本换行生成图片

    一.图片透明及旋转 let ctx = wx.createCanvasContext('shareImg') ctx.drawImage('../../../' + res[0].path, 0, 0 ...

  7. WordPress 网站开发“微信小程序“实战(二)

    原文链接:https://devework.com/wordpres...,转载请用明链注明来源,谢谢! 本文是"WordPress 开发微信小程序"系列的第二篇,本文记录的是开发 ...

  8. 2022DASCTF X SU 三月春季挑战赛 ezpop

    复现一道dactf的ezpop <?php class crow { public $v1; public $v2; function eval() { echo new $this->v ...

  9. linux系统引导过程

    linux系统引导过程 linux-0.11引导时,将依次运行BIOS程序.bootsect.s.setup.s和head.s,完成引导过程后进入到main函数运行.BIOS完成硬件的检查与初始化等工 ...

  10. ubantu系统之 lunch时报错:no such file /....../.lunchrc

    no such file /....../.lunchrc 出现时: 使用 source build/envsetup.sh 执行完后 再用lunch