PowerBI技巧之DAX的圈圈大坑:循环依赖关系错误circular dependency (单表篇).pdfVIP

PowerBI技巧之DAX的圈圈大坑:循环依赖关系错误circular dependency (单表篇).pdf

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
使用DAX中的某些函数特别类似Calculate这种函数创建计算列时很容易出现一种错误,叫做 测到循环依赖关 系,即:A circular dependency was detected。对于刚接触Dax语言的人来说,这个错误看着有点摸不到头脑, 整个公式使用上似乎没有任何问题,怎么会出现这个错误呢? 要排查这个错误,先了解一下循环依赖关系指的是什么。如下图所示,循环依赖关系简单的可以理解为,A由B 得出,而B又由A有关联关系。这就导致出现了一个循环的圈圈,你中有我,我中有你,然后,然后就是你和我 都分不清楚了。 在Dax中,循环依赖错误在创建计算列时比较容易出现,有的时候排查起来也可能很困难。由浅入深,这个blog 先介绍一下单张表中是如何出现循环依赖错误的。 先看下面这个最简单的产品销售报表,原始列有产品名 (Product ),单价 (Unit Price),成本 (Cost ),以及 销售量 (Sales Volume)。: 可以创建一个新的计算列 (column)Profit,用来计算每个产品的收益。 此时,我们还可以进一部的算一下每个产品的收益率%Profit,也就是收益占产品单价的比重。 目前一切都看起来平淡无奇。如果我们脑洞开一下,既然有了收益率,那么收益率 产品单价是不是可以反过来 推出产品收益呢?我们把原来的产品收益率计算公式从Unit Price - Cost改成%Profit Unit Price,看一下Power BI 的计算结果: 此时果不其然,有循环依赖关系的错误返回。这个理解起来很简单,因为%Profit是由Profit推出来的,而现在我 们又打算让DAX用%Profit去推Profit,这显然行不通。 这个例子看起来非常low,因为实际操作中是不会有人回头去改Profit计算公式而造成循环依赖关系的。但是这个 例子能说明一个很重要的问题,因为DAX中有一种很重要的概念叫上下文,我们在使用某些对上下文非常敏感 的函数时,很有可能就无意中掉进了这个循环依赖错误圈套里面,即虽然表面上看不到明显的A引用B,B又引 用A的关系,但是通过上下文这一作用,隐式的出现了A和B之间相互引用的错误。这一情况最容易出现在 Calculate函数身上。 还是用这个Product Table做例子,我们用CALCULATE+ SUMX函数对产品A来计算Total Sales。 计算结果没有什么问题,看起来很完美。同理的,我们套用这一公式对产品A来计算Total Cost 。然而,当我们 敲回车准备拿计算结果时,悲剧发生了,一个循环依赖错误蹦了出来。并且提示我们这个错误跟之前刚刚创建 的Total Sales有关系。 这个提示错误很崩溃,因为跟最开始Profit那个例子不一样,我们Total Sales和Total Cost里面用的列都是原数 据,根本就不存在推算关系。怎么用原数据计算的Total Cost就和Total Sales产生循环依赖关系了呢?原因吗, 就是出现在Calculate函数身上。 Calculate函数是一个重度上下文依赖函数,也就是说,当一个计算列中出现了Calculate函数后,你要特别小 心,因为当前行中所有的数据都可能跟Calculate函数的结果产生关系。 在当前例子中,当只有Total Sales这个计算列时,与其有关联关系的是: 元元素素 依依赖赖值值 SUMX Unit Price,Sales Volume 行: Product =A Product=A,Unit Price=75,Cost=49,Sales Volumn=10000 而当创建了Total Cost这个计算列时,整个Product是A的这一行上下文发生了变化,又增加了一列。这样对于用 重度上下文依赖关系的Calculate函数计算得出的Total Sales来讲,与其有关联关系的多了一个Total Cost 。即 元元素素 依依赖赖值值 SUMX Unit Price,Sales Volume 行: Product =A Product=A,Unit Price=75,Cost=49,Sales Volumn=10000,Total Cost=? 而同样的从Total Cost角度来看,从Product是A的这一行上下文关系中包含一个Total Sales=750,000值。这样 就隐式的出现了一个循环依赖关系,即Total Sales依赖To

您可能关注的文档

文档评论(0)

精通微软Word、Excel、PowerPoint、PowerBI,资料达人。

1亿VIP精品文档

相关文档