DAX/PowerBI系列 - 父子层级(Parent-Child Hierarchy)

难度: ★★☆☆☆(2星)

适用范围: ★★☆☆(3星)

应用场景:

其实很多时候对数据汇总都会有层级关系的问题,不过这个模式说的不是产品分类--子分类这样的场景,而说的是父和子都是存到同一个表中(通过一个父节点的字段指定parent),而且父节点和子节点也可能会产生业务数据。

以下是几个应用场景:


销售 - 组织架构层级

  销售员A卖产品,ta的下线a1,a2,a3也销售产品,如何统计ta和ta的下线一个卖了多少产品。

成本 - 产品和产品组件

  产品A有一个组装成本,产品组件a1,a2,a3也分别有它们的组装成本,要对总成本汇总。

盈亏 - 账户和关联子账户
打怪 - 大号与各个小号

欢迎交流与骚扰

Power BI显示如下:

以销售为例:

要点:

1.构建遍历结构
2.判断是否为末节点
3.定义遍历层级
4.当计算当前元组对应的浏览的节点深度

  

注意:由于用中文来命名表/列名并用此来写DAX比较痛苦,试了几次都觉得不太顺手,最后还是用英文了,(⊙o⊙)…

欢迎转载,请保留原文链接和作者信息。O(∩_∩)O谢谢。
DAX/PowerBI系列 - 父子层级(Parent-Child Hierarchy) 作者:马丁叔叔
链接:http://www.cnblogs.com/lizardbi/p/DAX-PATTERN-POWERBI-Parent-Child-Hierarchy.html 

1. 构建遍历机构 - 用PATH语句拿到各个人的上线

[Path] = PATH ( Nodes[Name], Nodes[Parent] )

2. 判断末节点

先来看看那些是末节点:

[IsLeaf] =
CALCULATE (
COUNTROWS ( Nodes ),
ALL ( Nodes ),
Nodes[ParentKey] = EARLIER ( Nodes[NodeKey] )

) = 0

3. 构建遍历层级

看看几层都有谁:

[HierarchyDepth] = PATHLENGTH ( Nodes[HierarchyPath] )

[Level1] =
LOOKUPVALUE (
Nodes[Name],
Nodes[NodeKey],
PATHITEM ( Nodes[HierarchyPath], 1, INTEGER )
) [Level2] =
IF (
Nodes[HierarchyDepth] >= 2,
LOOKUPVALUE (
Nodes[Name],
Nodes[NodeKey],
PATHITEM ( Nodes[HierarchyPath], 2, INTEGER )
),
Nodes[Level1]
) [Level3] =
IF (
Nodes[HierarchyDepth] >= 3,
LOOKUPVALUE (
Nodes[Name],
Nodes[NodeKey],
PATHITEM ( Nodes[HierarchyPath], 3, INTEGER )
),
Nodes[Level2]
)

4.计算当前元组对应的浏览的节点深度,用于计算

BrowseDepth = ISFILTERED ( Nodes[Level1] )
+ ISFILTERED ( Nodes[Level2] )
+ ISFILTERED ( Nodes[Level3] )
 

假如简单的计算,

[Sales Amount Simple] :=
IF (
[BrowseDepth] > [MaxNodeDepth],
BLANK (),
SUM ( Transactions[Amount] )
)

问题:

你会发现:上面有图并没有显示Brad和Annabel各自的值[Sales Amount Simple],但是他们现在汇总的值却比他们对应的子节点的总和要大。

譬如:Brad子节点汇总应该为(Chris400 + Vince500 = 900),但是Brad却为1300。而Brad本身400并没有显示出来。

改进:

[Sales Amount] :=
IF (
[BrowseDepth] > [MaxNodeDepth] + 1,
BLANK (),
IF (
[BrowseDepth] = [MaxNodeDepth] + 1,
IF (
AND (
VALUES ( Nodes[IsLeaf] ) = FALSE,
SUM ( Transactions[Amount] ) <> 0
),
SUM ( Transactions[Amount] ),
BLANK ()
),
SUM ( Transactions[Amount] )
)
)

上面为原文给出的计算,可以看到 左图为pivot table勾选了显示没有数据的显示,右图为不显示没有数值的行。注意这里要显示Subtotal才会显示中间的节点和根节点,如果不勾选的话就会得到下图。

正如下面左边,在PowerBI里面,并没有正确的显示。

再改进:

Sales $ =
IF (
[BrowseDepth] > [MaxNodeDepth] + 1 ,
IF (
AND (
VALUES ( Nodes[IsLeaf] ) = FALSE,
SUM(Transactions[Amount]) <> 0
),
SUM(Transactions[Amount]),
BLANK ()
),
SUM(Transactions[Amount])
)

Excel显示如下:左边为隐藏没有数据的行,右边显示了没有数据的Bill

PowerBI显示如下:

左边是上面改进前的[Sales Amount]的显示,右图是上面[Sales $]的显示。最后一列才是我想要的。

右上的图可以drill-down,如果想玩,可以在这里下载。链接: https://pan.baidu.com/s/1geJe3yN 密码: hfh7

好了,这算是在DAX patterns里面入门级的一个了。

PowerBI戳这里: https://app.powerbi.com/view?r=eyJrIjoiNWM0ZGYwYTMtYTk4Yy00ODE0LTlmNTItZGJmMDkzYTVlOGYyIiwidCI6ImQxYWY4NDdiLTJjZTEtNDRjYi1iYjUwLWQ1ODAyYmI0M2M4YiIsImMiOjEwfQ%3D%3D

参考文章:http://www.daxpatterns.com/parent-child-hierarchies/

欢迎围观和讨论。。。

DAX/PowerBI系列 - 父子层级(Parent-Child Hierarchy)的更多相关文章

  1. DAX/PowerBI系列 - 参数表(Parameter Table)

    DAX/PowerBI系列 - 参数表(Parameter Table) 难度: ★☆☆☆☆(1星) 适用范围: ★★★★☆(4星) 概况: 这个模式比较简单灵活,而且很实用.所用的DAX语句也比较简 ...

  2. DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension)

    跟大家的交流是我的动力. :) DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension) 难度: ★☆☆☆☆(1星) 适用范围: ★ ...

  3. DAX/PowerBI系列 - 玩转阿里云 Alicloud Pricing

    DAX/PowerBI系列 - 玩转 阿里云主机 Ali Cloud ECS 难度: ★★☆☆☆(1星) 适用范围: ★★★☆☆(3星) 欢迎交流与骚扰 这是啥: 双十一就到了,码农门,程序猿们有没有 ...

  4. DAX/PowerBI系列 - 关于时间系列 - 时间相关数值比较 - 用非自带函数

    DAX/PowerBI系列 - 关于时间系列 - 时间相关数值比较 - 用非自带函数 文末有彩蛋,解决蛋疼问题 难度: ★★☆☆☆(2星) 适用范围: ★★★☆☆(3星) 概况: 基于时间的汇总可能是 ...

  5. (玩起来)DAX/PowerBI系列 - 参数表(Parameter Table) - 多时间段数值对比

    盆友们,边看文章边玩,请耐心等待PowerBI load出来~~~~ (7.8秒钟) DAX/PowerBI系列 - 参数表(Parameter Table) - 多时间段数值对比 难度: ★☆☆☆☆ ...

  6. DAX/PowerBI系列 - 累计总计(Cumulative Total)

    DAX/PowerBI系列 - 累计总计(Cumulative Total) 2017/07/23 更新:B列公式(见最后) 难度: ★★☆☆☆(2星) 适用: ★★☆☆☆(2星) 概况: 这个模式普 ...

  7. DAX/PowerBI系列 - 参数表(Parameter Table) 度量值模板

    DAX/PowerBI系列 - 参数表(Parameter Table) 度量值模板 难度: ★★☆☆☆(2星) 适用范围: ★★★☆☆(3星) 概况: 当你有多个度量值都需要计算YTD,MoM,而又 ...

  8. DAX/PowerBI系列 - 库存总价值(Inventory Value)

    DAX/PowerBI系列 - 库存总价值(Inventory Value) 欢迎交流与骚扰 难度: ★★☆☆☆(2星) 适用: ★★☆☆☆(2星) 概况: 有多少货(库存)当然重要(对于运营人员), ...

  9. DAX/PowerBI系列 - 参数表(Parameter Table) - 大客户分析(Top N)

    DAX/PowerBI系列 - 参数表(Parameter Table) - 大客户分析(Top N) 难度: ★☆☆☆☆(1星) 适用范围: ★★★☆☆(3星) 概况:此文为DAX/PowerBI系 ...

随机推荐

  1. 响应HttpServletResponse

    可以使用HttpServletResponse来对浏览器进行响应,大部分情况下,会使用setContentType()设置响应类型,使用getWriter()取得PrintWriter对象,而后使用P ...

  2. Postgresql standby(备机只读)环境搭建

    下载PostgreSQL源码包,放在任意目录 设置/etc/sysctl.conf,增加以下内容 kernel.shmmni= 4096 kernel.sem =501000 6412800000 5 ...

  3. C++中的Traits技法

    Traits广泛应用于标准程序库.Traits classes使得"类型相关信息"在编译期可用. 认真读完下面的示例,你应该就懂了Traits技法,其实并不难. #include ...

  4. WinMerge文件编码设置

    http://blog.sina.com.cn/s/blog_7575fab10101o0na.html 系统默认是System codepage,我们要选用Custom codepage.值得注意的 ...

  5. 基于Ubuntu 14.04构建tomcat7镜像

    1.创建Dockerfile文件(如果在Windows下编辑文件,一定要将格式转化为Linux格式文件,否则将导致Linux下查看文件每行多一个^M) # Pull base image FROM u ...

  6. PrefixSpan算法原理总结

    前面我们讲到频繁项集挖掘的关联算法Apriori和FP Tree.这两个算法都是挖掘频繁项集的.而今天我们要介绍的PrefixSpan算法也是关联算法,但是它是挖掘频繁序列模式的,因此要解决的问题目标 ...

  7. yii2 中布局文件的 设置方法

    网页主题应用的属性: [yii\base\Application::layout|layout 该属性指定渲染 视图 默认使用的布局名字,默认值为 'main' 对应布局路径下的 main.php 文 ...

  8. [CSS3] 学习笔记-选择器详解(三)

    1.UI元素状态伪类选择器 在CSS3的选择器中,除了结构性伪类选择器外,还有一种UI元素伪类选择器.这些选择器的共同特征是:指定的样式只有当元素处于某种状态时才起作用,在默认状态下不起作用.在CSS ...

  9. 关于data-xxx属性大小写不敏感,不识别大写的几点总结

    1.所有标签属性,没有大小写区分,都是小写,如:data-userID,在输出后会变成data-userid,前者只能获取到'undefined'. 2.dataset 自动把 - 转换为驼峰.类似的 ...

  10. css3 3D效果

    css3 3D变形 transfrom初学 这个礼拜学了css3 3d,感觉到css无穷的魅力,可以通过几个特定的代码符号创建出3D效果的页面. ___ 透视 一个元素需要一个透视点才能激活3D空间, ...