人生没有彩排
每一天都是现场直播

PowerBI

在PowerBI中使用跨事务任务流实现自定义备注 - 枫言枫语

在PowerBI中使用跨事务任务流实现自定义备注

前言 关于数据回写的一个应用,即让用户可以在PowerBI报表中自定义备注信息,这个功能在之前的文章中已经分享过实现方案了,但之前的实现方案需要借助第三方的视觉对象,实现起来较复杂,且自由度和用户体验上还是差了一点。 而在2025年05月的...

夕枫

Fabric用户数据函数的介绍 - 枫言枫语

Fabric用户数据函数的介绍

前言 Fabric用户数据函数其实是一个可以在Fabric上托管和运行的自定义API服务,与Azure Functions有点类似。 借助Fabric用户数据函数,可以轻松的根据自身需求来定制和创建API,并可以和Fabric或微软的其他服...

夕枫

PowerBI计算组的选择表达式的应用 - 枫言枫语

PowerBI计算组的选择表达式的应用

前言 PowerBI的计算组是一个很强大的功能,它能够批量更改度量值的计算逻辑,并提供了动态数据格式功能,能够帮助我们实现许多技巧,在某些场景下具有不可代替的作用。而在2025年5月18日的更新中,计算组又迎来了一次增强,新增的选择表达式能...

夕枫

45、理解GENERATE函数 - 枫言枫语

45、理解GENERATE函数

GENERATE函数也可以生成笛卡尔积组合,但与CROSSJOIN函数不同的是,GENERATE函数可以根据不同行来与不同的表产生笛卡尔积。 语法和作用 语法:GENERATE ( Table1, Table2 ) 作用:对Table1的每...

夕枫

44、理解CROSSJOIN函数 - 枫言枫语

44、理解CROSSJOIN函数

CROSSJOIN函数可以生成多个表的笛卡尔积组合,经常被用于模拟视觉对象的计值环境,以及处理明细正确但总计不正确等场景。 语法和作用 语法: CROSSJOIN ( table1, table2, [tableN... ] ) 作用:返回...

夕枫

43、理解TOPN函数 - 枫言枫语

43、理解TOPN函数

TOPN函数也是必须掌握的函数,它可以返回指定表按指定条件进行排序后的前N行,经常用于计算头部产品或客户等分析场景。 语法和作用 语法: TOPN(n_value, table, orderBy_expression, [order[, o...

夕枫

42、理解RANKX函数 - 枫言枫语

42、理解RANKX函数

RANKX函数是DAX函数中的核心函数之一,可以用来对数据进行排名,虽然有些窗口函数也可以实现排名,但RANKX仍然是必须要掌握的函数。 语法和作用 语法: RANKX(table, expression[, value[, order[,...

夕枫

41、理解SELECTEDVALUE函数 - 枫言枫语

41、理解SELECTEDVALUE函数

SELECTEDVALUE函数也是使用频率比较高的一个函数,经常用于获取切片器或矩阵行列标签等筛选器中被筛选的单个值。 语法和作用 语法: SELECTEDVALUE(columnName[,alternateResult]) 作用:如果指...

夕枫

40、理解HASONEFILTER函数 - 枫言枫语

40、理解HASONEFILTER函数

HASONEFILTER函数与HASONEVALUE函数基本一模一样,唯一区别就在于,HASONEVALUE函数考虑的是交叉筛选,而HASONEFILTER函数只考虑其参数所指定列的直接筛选,除此之外,它们的行为全都一致。 语法和作用 语法...

夕枫

39、理解HASONEVALUE函数 - 枫言枫语

39、理解HASONEVALUE函数

HASONEVALUE函数的使用频率也很高,它可以判断指定列的可见数据去重后是不是只有一个值,经常用于判断矩阵所处的层级,以及作为将表当作标量值来使用时的保护机制。 语法和作用 语法:HASONEVALUE(columnName) 作用:如...

夕枫

38、理解SELECTCOLUMNS函数 - 枫言枫语

38、理解SELECTCOLUMNS函数

SELECTCOLUMNS函数与ADDCOLUMNS函数非常类似,SELECTCOLUMNS函数也是迭代表的每一行并计算所给的表达式,最后给表添加新列,但它最终只返回新添加的派生列,而不会返回原有列。 语法和作用 语法: SELECTCOL...

夕枫

37、理解ADDCOLUMNS函数 - 枫言枫语

37、理解ADDCOLUMNS函数

ADDCOLUMNS函数是一个表函数,同时也是迭代函数,它会像计算列一样,迭代表的每一行并计算所给的表达式,最后给表添加一个新列。 语法和作用 语法: ADDCOLUMNS(table_expression, name, expressio...

夕枫

PowerBI的“值筛选行为”功能的介绍 - 枫言枫语

PowerBI的“值筛选行为”功能的介绍

前言 在2024年10月,PowerBI更新了一个名为“值筛选行为”的功能,目的是为了修复Auto-Exists机制中的Bug。但由于海量的报表已经运行在这个Bug的基础之上,影响范围过大,且Bug的行为相对稳定可重复,已经逐渐演变成了一个...

夕枫

PowerBI中度量值所处的计值环境研究 - 枫言枫语

PowerBI中度量值所处的计值环境研究

前言 在前面介绍自动匹配原理的文章中,有提到Auto-Exists机制本身就存在Bug,那么本篇文章就来探讨一下这个问题,而这个问题其实就是对度量值所处的计值环境的研究。 这个Bug其实PowerBI官方也是清楚的,但由于海量的报表已经运行...

夕枫

36、理解自动匹配(Auto-Exists) - 枫言枫语

36、理解自动匹配(Auto-Exists)

自动匹配(Auto-Exists)是DAX引擎的一个优化机制,主要目的是为了剔除无效运算来提升计算速度。但自动匹配的优化机制除了会影响底层实现外,它还会对计值环境造成影响,如果不理解这个机制的话很容易就会出现错误,特别是这个优化机制本身就存...

夕枫

35、理解数据沿袭 - 枫言枫语

35、理解数据沿袭

数据沿袭(Data Lineage)是一个很重要且设计很巧妙的特性,它决定了各种筛选器能否筛选模型中的数据,以及使用什么姿势来筛选。同时,DAX引擎以一种自然且直观的方式来处理数据沿袭的复杂性,在编写表达式时通常不需要考虑它,以至于大多数用...

夕枫

34、交叉筛选和直接筛选 - 枫言枫语

34、交叉筛选和直接筛选

当某个表或字段被筛选时,其被筛选的原因或类型可以分为两种,即交叉筛选和直接筛选。理解清楚交叉筛选和直接筛选的概念和区别,可以有助于实现更细腻的操作和技巧。 交叉筛选与直接筛选的概念 当针对列时,如果这个列被筛选了,且出现筛选的原因是其自身列...

夕枫

33、循环依赖和主键 - 枫言枫语

33、循环依赖和主键

某个表达式在计算时如果引用了其他对象,则称之为依赖,有线性依赖与循环依赖两种。其中,循环依赖是不正常的依赖关系,当检测到循环依赖时会报错,而线性依赖则是正常的行为,并不会报错。 循环依赖指的是两个对象在计算时互相依赖,比如想要计算A就要先得...

夕枫

32、应用日期表时的注意事项 - 枫言枫语

32、应用日期表时的注意事项

在PowerBI中,日期维度是非常常见的一个维度,基本上各种数据分析需求都会对日期范围有所要求,也就是说各个事实表基本上都会存在日期字段,所以在PowerBI中的一个最佳实践就是创建日期表来统一管理日期维度,这就要求我们对日期表的一些特殊行...

夕枫

31、查询关键字 - 枫言枫语

31、查询关键字

在做DAX查询时必须先声明EVALUATE关键字,但除此之外,还有其它可选的查询关键字,比如:ORDER BY、START AT、DEFINE等等。不同的查询关键字有不同的作用,灵活运用各种查询关键字能够更好的控制DAX查询返回的结果。本篇...

夕枫