- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
- PowerBI技巧之PowerQuery 导入Excel 内容-PowerQuery 系列文章之五.pdf
- PowerBI技巧之PowerBuilder中quick select类型的datawinow数据源控件中添加查询参数.pdf
- PowerBI技巧之PowerBI实用技巧:案例五(巧用Switch函数展现指标RGB颜色).pdf
- PowerBI技巧之PowerBI实用技巧:案例三(动态参数筛选控制排名的展示——DAX RANKX).pdf
- PowerBI技巧之PowerBI-日期和时间函数-YEAR_QUARTER_MONTH_DAY.pdf
- PowerBI技巧之PowerBI-日期和时间函数-DATE_EDATE_DATEVALUE.pdf
- PowerBI技巧之PowerBI-日期和时间函数-CALENDAR_CALENDARAUTO.pdf
- PowerBI技巧之PowerBI(Excel)提取Web数据-PowerQuery系列文章之十(Excel篇).pdf
- PowerBI技巧之PowerBI(Excel)导入XML数据-PowerQuery系列文章之六.pdf
- PowerBI技巧之PowerBI(Excel)导入Mysql 数据库中的数据.pdf
- PowerBI技巧之DAX_PowerBI系列 - 玩转阿里云 Alicloud Pricing.pdf
- PowerBI技巧之DAX_PowerBI系列 - 库存总价值(Inventory Value).pdf
- PowerBI技巧之DAX_PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度.pdf
- PowerBI技巧之DAX_PowerBI系列 - 查询参数用法详解(Query Parameter).pdf
- PowerBI技巧之DAX_PowerBI系列 - 参数表(Parameter Table).pdf
- PowerBI技巧之DAX_PowerBI系列 - 参数表(Parameter Table) 度量值模板.pdf
- PowerBI技巧之DAX_PowerBI系列 - 参数表(Parameter Table) - 大客户分析(Top N).pdf
- PowerBI技巧之DAX Studio--导出PowerBi数据.pdf
- PowerBI技巧之DAX CountX+RelatedTable实战:帮助HR妹子创建一个工作日历表.pdf
- PowerBI技巧之COSCon'20 & Apache Roadshow- China 精彩收官 _ 数据篇.pdf
最近下载
- 2025年公安招聘辅警考试笔试题及答案.docx VIP
- (完整word)二次函数练习顶点式基础练习题 .pdf VIP
- 2025年公安局警务辅助人员招聘考试笔试试题(附答案).docx VIP
- 2025-2026学年苏科版劳动五年级上册教学计划及进度表.pdf VIP
- 干式变压器技术规范书.docx VIP
- 2025年西藏自治区昌都市护士基础理论知识考试题库及答案解析.pdf VIP
- 工程建设监理收费标准(发改价格2022670号).docx VIP
- 2025年黑龙江省绥化市辅警招聘考试题库及答案.docx VIP
- 操作手册模板【范本模板】.pdf VIP
- 幼儿园角色扮演的重要性和意义.docx VIP
文档评论(0)