什么是按列排序
按列排序功能允许使用另一列的值来对当前列进行排序。例如,想按月份的自然顺序(如一月、二月、三月)显示数据,而不是按字母顺序排序,可以将月份名称列的排序依据设置为月份序号列,这能确保数据显示的顺序符合业务逻辑。
DAX 查询中的列排序规则
在 Power BI 中,DAX 查询没有默认的列排序规则,必须使用 ORDER BY
明确指定。如果列设置了“按列排序”,DAX 查询会同时包含用于显示的列(如“月份名称”)和排序依据的列(如“月份序号”)。
例如,在 Power BI 中一个包含月份名称(已经按列排序)和销售额的表,其 DAX 查询如下:
即使报表中只显示月份名称,查询仍包含月份序号以确保正确排序。
按列排序的“副作用”
当 DAX 查询同时包含用于显示的列和排序依据的列时,可能会对筛选上下文和度量值的结果产生影响。
例如,如果报表同时包含月份名称和月份序号,筛选上下文可能会影响度量值的计算结果。比如我们要计算月份销售额最大值,那么对应的度量值如下。
月份销售额最大值 =
MAXX( ALL( 'Dim Calendar'[MonthNameCN] ) , [Sales] )
添加到表上时,发现计算错误。
这是因为筛选上下文包含了月份序号列,度量值未移除与排序相关的筛选上下文。
将度量值修改一下,移除排序列的筛选上下文。
月份销售额最大值 =
MAXX( ALL( 'Dim Calendar'[MonthNameCN] , 'Dim Calendar'[MonthNum] ) , [Sales] )
此时发现计算正确。
所以我们在移除进行过按列排序操作列的筛选上下文时,要注意不仅只有报表中使用的列的筛选上下文要移除,它所依靠的排序列的筛选上下文也要移除,这样才能计算正确。
除了按列排序,我们之前也介绍过一种超越按列排序的列自定义排序方法,使用 UNICODE 空字符 + REPT 实现,完全依靠字母排序。相对于案列排序,不用新建列,不用担心筛选上下文错误。
总结
当在 Power BI 中使用“按列排序”功能时,需注意同时处理排序相关的两列。通过调整筛选逻辑和公式,避免因筛选上下文不一致而导致的计算错误。掌握这些最佳实践,可以提高报表的准确性和一致性,为用户提供更优质的数据展示体验。
一更专业的数据分析师训练营一
📈【高级课程】:业务人(管理、销售、财务、供应链)彻底解决企业数据分析。
🔍【企业咨询】:十大行业,十大领域,企业案例,咨询,培训,实施。
🔗 如何获取更多信息?扫描下方二维码具体咨询。
点击“阅读原文”获取更多资源