美文网首页BI学习笔记
函数周期表丨筛选丨表丨VALUES

函数周期表丨筛选丨表丨VALUES

作者: Fabric丨白茶 | 来源:发表于2020-12-12 10:11 被阅读0次

    VALUES函数

    VALUES函数,隶属于“筛选”类函数。当参数为列时,返回结果会去除重复值,保留空项;当参数为表时,结果不会进行去重复操作。

    用途:适用于度量值计算。

    语法

    DAX=
    VALUES(表or列)
    

    参数

    VALUES函数的参数可以是列,也可以是表,但不能是表达式。

    返回结果

    去除重复值的列或者返回一个完整的表。当表为单列单行时,可以作为值使用。

    例子

    模拟数据:

    这是白茶随机模拟的数据,红色框为重复数据,蓝色框为维度不存在的数据。坦白说,其实单个的VALUES函数没什么好说的,甚至不用枚举太多的例子,小伙伴们都是了解的,因为使用度非常高。

    白茶会将VALUES函数、DISTINCT函数、ALL函数做一个比较,让大家明白三者的区别。

    例子1:表函数模式

    代码1:

    VALUES例子1 =
    VALUES ( '例子' )
    

    代码2:

    DISTINCT例子1 =
    DISTINCT ( '例子' )
    

    代码3:

    ALL例子1 =
    ALL ( '例子' )
    

    结果:

    1、表函数模式下,DISTINCT会对表进行去重操作;而VALUES和ALL函数相当于复制操作,并不会对源文件进行去重。

    2、DISTINCT参数可以是表达式,而VALUES和ALL的参数不能是表达式。

    例子2:参数列模式

    代码1:

    VALUES例子2 =
    VALUES ( '例子'[类别] )
    

    代码2:

    DISTINCT例子2 =
    DISTINCT ( '例子'[类别] )
    

    代码3:

    ALL例子2 =
    ALL ( '例子'[类别], '例子'[数据] )
    

    1、三个函数的参数如果都是列的话,在表函数模式下,都会进行去重复操作。

    2、ALL函数的列参数可以有多个,类似于笛卡尔积的效果;而DISTINCT和VALUES函数列参数只能有一个。

    例子3:度量值情况

    代码1:

    统计行数 =
    COUNTROWS ( '例子' )
    

    代码2:

    VALUES统计 =
    SUMX ( VALUES ( '维度'[类别] ), CALCULATE ( COUNTROWS ( '例子' ) ) )
    

    代码3:

    DISTINCT统计 =
    SUMX ( DISTINCT ( '维度'[类别] ), CALCULATE ( COUNTROWS ( '例子' ) ) )
    

    代码4:

    ALL统计 =
    SUMX ( ALL ( '维度'[类别] ), CALCULATE ( COUNTROWS ( '例子' ) ) )
    

    结果:

    在例子和维度上下文中,DISTINCT函数排除掉因扩展表原因导致的空值项目,将其排除在计算范围之内;进行的是去除重复,排除空值计算。

    无论在例子上下文还是维度上下文中,VALUES函数的计算都包含空值项目。

    ALL函数在例子上下文中的计算,没有屏蔽掉例子的筛选效果,其计算结果包含空值项目;而在维度上下文中,清除了维度表的筛选效果,计算结果包含空值项目,每个返回值均为总计行数37。

    以上,就是关于VALUES、DISTINCT、ALL三个函数之间的主要区别了。可能在一些场合,三者返回的结果是一致的,就给我们造成了三者效果差不多的错觉,实际上三者之间的差距还是蛮大的。


    小伙伴们❤GET了么?

    白茶会不定期的分享一些函数卡片

    (文件在知识星球[PowerBI丨需求圈])

    这里是白茶,一个PowerBI的初学者。

    相关文章

      网友评论

        本文标题:函数周期表丨筛选丨表丨VALUES

        本文链接:https://www.haomeiwen.com/subject/gjbyahtx.html