[]
        
(Showing Draft Content)

CALCULATE

概述

在已修改的筛选器上下文中计算表达式。

语法

分析表达式

CALCULATE(<expression>[, <filter1> [, <filter2> [, …]]])

参数

参数

定义

expression

要进行求值的表达式。

filter1, filter2,…

(可选)定义筛选器或筛选器调整函数的布尔表达式或表表达式。

用作第一个参数的表达式与度量基本相同,第一个参数可以是计算表达式。

筛选器可以是:

  • 布尔筛选表达式

  • 表筛选表达式

  • 筛选器调整函数

当有多个筛选表达式时,可以使用 AND (&&) 逻辑运算符对它们进行计算,这意味着所有条件都必须为 TRUE。

布尔筛选表达式示例

分析表达式

CALCULATE (
    SUM ( Sales[Sales Amount] ),
    'Sales'[OrderDateKey] > 1 && 'Sales'[OrderDateKey] <100
)

表筛选表达式示例

表表达式筛选器将表对象应用为筛选器。 它可以是对模型表的引用,但更有可能是返回表对象的函数。

分析表达式

CALCULATE (
    SUM ( Sales[Sales Amount] ),
    Filter('Sales','Sales'[OrderDateKey] > 1 && 'Sales'[OrderDateKey] <100)
)

布尔过滤器和表过滤器之间的区别。

类型

描述

布尔筛选表达式

此过滤器作为 where 子句,添加在连接表之后。

表筛选表达式

此过滤器作为表将进行内部连接。

筛选器调整函数

通过筛选器调整函数,不仅仅可以添加筛选器。 它们还在修改筛选器上下文时为您提供额外的控制。

在此版本中,我们仅提供“REMOVEFILTERS”功能。它只能去除不必要的维度。示例如下。

在计算Sales Amount合计时,忽略维度CustomerName。在实际使用时经常作为分母计算总的销售额。

分析表达式

CALCULATE (
    SUM ( Sales[Sales Amount] ),
    REMOVEFILTERS('Sale'[CustomerName])
)

返回值

返回表达式的计算结果。

示例

计算满足三个筛选条件时的Sales Amount 合计。

分析表达式

CALCULATE (
    SUMX ('Sales', Sales[Sales Amount] ),
    'Sales'[OrderKey] > 20 && 'Sales'[OrderKey] <1010,
    Filter('Sales','Sales'[OrderDateKey] > 1 && 'Sales'[OrderDateKey] <100),
    REMOVEFILTERS('Sale'[CustomerName])
)

备注

所有的过滤表达式都会作用于第一个参数的内表。这意味着 CALCULATE 函数中的过滤器表达式是一个预过滤器。