过滤器函数允许你操纵筛选上下文以创建动态的计算,是DAX中最复杂和最强大的一类函数,本文记录我对一些常见的过滤器函数的总结。

一,筛选上下文的构成

DAX中的筛选上下文由三部分构成:交叉过滤构成的过滤,查询上下文中每行的列值构成的过滤,外部切片器构成的显式过滤。

1,交叉过滤器

在数据模型中创建关系,指定交叉过滤器

2,查询上下文

在当前查询的上下文中,每行的列值也会作为过滤器,例如,ProductCategoryName和Color是当前查询上下文的行过滤器:

3,外部切片器

在报表中设置的切片器,是在查询上下文外部的设置的过滤器,例如,上图中的Color切片器就是外部切片器。

二,清除过滤器

ALL系列的函数能够从上下文中清除已经应用的过滤器。

1,ALL

ALL 函数用于清除表上的所有过滤器,返回表中的所有行,或者一列的所有值,适用于对表中的所有行进行汇总计算。注意,此函数只能用于基础表(base table),不能用于表表达式或列表达式。

ALL( [<table> | <column>[, <column>[, <column>[,…]]]] )  

2,ALLCROSSFILTERED

ALLCROSSFILTERED函数用于清除应用到表上的所有过滤器,该函数不返回任何值,仅仅用于清除表上的过滤器。

ALLCROSSFILTERED(<table>)

例如,计算FactInternetSales表上所有OrderQuantity的值:

= CALCULATE(SUM(FactInternetSales[OrderQuantity]), ALLCROSSFILTERED(FactInternetSales))

3,ALLEXCEPT

ALLEXCEPT函数用于移除其他字段的所有过滤器,而保留参数指定的字段上的过滤器,

ALLEXCEPT(<table>,<column>[,<column>[,…]]) 

返回一个表,除了参数指定的字段上的过滤器之外,其他字段的过滤器都被移除,例如,保留 DateTime[CalendarYear] 字段上的过滤器,表DateTime中其他字段的过滤器都被移除:

= CALCULATE(SUM(ResellerSales_USD[SalesAmount_USD]), ALLEXCEPT(DateTime, DateTime[CalendarYear]))

4,ALLSELECTED

ALLSELECTED 的作用是从当前查询的上下文中移除的行和列的过滤(即忽略行和列的过滤),而保留当前查询除行和列之外的上下文过滤器或显式定义的过滤器(例如切片器等):

ALLSELECTED([<table> | <column>[, <column>[, <column>[,…]]]] )  

参数table和column是可选的,如果有多个column参数,那么这些column必须来自同一个table。返回值是不包括行和列过滤器的查询上下文。

例如,计算选定的颜色和分类的产品销售数量的占比。在报表中设置切片器,共选择了4种颜色,这是报表显式定义的过滤器。

  • 当前查询的上下文过滤器是由ProductCategory和Color,以及外部的切片器构成的;
  • 分母的计算逻辑是移除当前查询的上下文过滤器,也就是不管产品ProductCategory和Color,计算4种Color(外部切片器决定)对应的产品销售的总量,四种颜色对应的SalesAmount总量是12944190.35。
  • 分子的计算逻辑是在当前查询的上下文中,计算特定的ProductCategory和Color的产品销售的数量。例如,颜色为Red的Bikes的销售总量是7646302.82,除以SalesAmount总量12944190.35,约等于0.59。
SalesRateBySelectedColors = DIVIDE(CALCULATE(SUM( FactSales[SalesAmount]))*1.0, CALCULATE(SUM(FactSales[SalesAmount]),ALLSELECTED()))

5,REMOVEFILTERS

移除过滤器,不会返回表

REMOVEFILTERS([<table> | <column>[, <column>[, <column>[,…]]]])

三,添加过滤器

在DAX中对表进行过滤,用于在表达式中增加过滤器:

FILTER(<table>,<filter>) 

参数是布尔表达式,用于逐行执行,对表进行过滤,返回结果为True的行,而把结果位False的行移除,例如:

FILTER(FactSales, [Amount] >  or [Region] = "France")

四,直接过滤和交叉过滤

数据模型中的过滤分为直接过滤和交叉过滤:

直接过滤:当过滤直接作用到表中的列col上时,列col是被直接过滤的。直接过滤是由外部的切片器和查询上下文中的行和列过滤器确定的,不受交叉过滤器的影响。

注意:如果外部切片器没有勾选任何选项时,默认显示基础表中所有的唯一值。

交叉过滤:当过滤作用于同一个表的另一列B上,或作用于相关表上时,列A是被交叉过滤的,交叉过滤收到所有筛选上下文的影响。

direct_filtered_colors = COUNTROWS((FILTERS(DimProduct[Color])))
cross_filtered_distinct_colors = COUNTROWS((DISTINCT(DimProduct[Color])))
cross_filtered_values_colors = COUNTROWS((VALUES(DimProduct[Color])))

结果分析:

direct_filtered_colors:是直接过滤,不受交叉过滤上下文的影响,直接显式基础表中Color的唯一值的数量,

cross_filtered_values_colors 和 cross_filtered_distinct_colors :是交叉过滤,受到交叉过滤上下文的影响,只统计被过滤之后的Color的数量。

1,判断是直接过滤还是交叉过滤

直接过滤和交叉过滤可以通过函数来识别:

ISCROSSFILTERED(<columnName>)
ISFILTERED(<columnName>)

2,返回过滤的唯一值

移除重复,只保留唯一值,当返回直接过滤的唯一值时,使用FILTERS()函数:

FILTERS(<columnName>) 

当返回交叉过滤的唯一值时,使用DISTINCT 和 VALUES函数,这两个函数都受到过滤上下文的作用。唯一的区别是:

当原始表中不存在BLANK时,DISTINCT 只返回原始表中的值,而VALUES可能会返回BLANK,该数据是被添加到查询中用于表示不相关的行。

DISTINCT 和 VALUES函数的定义是:

DISTINCT(<table | column>)
VALUES(<Table | Column>)

3,检查唯一

当直接过滤的唯一值只有一个时,返回True;否则返回False。

HASONEFILTER(<columnName>)

该函数等价于:

COUNTROWS(FILTERS(<columnName>)) = 

当列上下文中只有一个唯一值时,返回True;否则,返回False

HASONEVALUE(<columnName>) 

该函数等价于:

COUNTROWS(VALUES(<columnName>)) = 

4,SELECTEDVALUE

当column的上下文被过滤为只有一个唯一值时,返回该唯一值,否则返回alternateResult。

SELECTEDVALUE(<column>[, <alternateResult>])  

该函数等价于:

IF(HASONEVALUE(<column>), VALUES(<column>), <alternateResult>)

五,关联值

关联需要当前表和关联表之间存在关系。跟当前行相关的唯一值,该函数不受任何过滤器的影响:

RELATED(<column>) 

RELATED函数需要当前表和关联表之间存在关系,在函数中指定包含你需要数据的列,该函数遵循现有的多对一关系,以从相关表的指定列中获取一个值,也就是说,RELATED函数从多方关联到1方的一个值,参数column是1方表中的列。当RELATED函数执行查找时,它会检查指定表中的所有值,而不管可能已应用的任何过滤器。

注意:RELATED函数需要行上下文,因此,只能用于计算列表达式中(其当前行上下文是明确的) 和表扫描函数中。表扫描函数(如SUMX)获取当前行的值,然后扫描关联表以查找指定列的关联值。

例如,从下图中可以看到,FactSales和DimProduct之间存在 “*对1” 的关系,并且FactSales是多方,DimProduct是1方。可以在RELATED()函数中指定DimProduct表中的列,以从DimProduct表获得跟FactSales中某一行相关联的值。

在FactSales表中创建计算列,获取跟当前行相关的产品颜色的值:

Related_color = RELATED( DimProduct[Color]) 

参考文档:

Filter functions

allselected()函数

DAX 第三篇:过滤器函数的更多相关文章

  1. 深入理解this机制系列第三篇——箭头函数

    × 目录 [1]痛点 [2]解决 [3]基本用法[4]回调函数[5]注意事项 前面的话 this机制与函数调用有关,而作用域则与函数定义有关.有没有什么是可以将this机制和作用域联系起来的呢?本文将 ...

  2. Python成长之路【第三篇】函数

    函数 一.背景 在学习函数之前,一直遵循:面向过程编程,即:根据业务逻辑从上到下实现功能,其往往用一长段代码来实现指定功能,开发过程中最常见的操作就是粘贴复制,也就是将之前实现的代码块复制到现需功能处 ...

  3. python 【第三篇】函数基础

    深浅拷贝 set是一个无序且不重复的元素集合访问速度快天生解决重复问题 #!/usr/bin/env python3 # -*- coding:utf-8 -*- #深浅拷贝 import copy ...

  4. python【第三篇】函数

    内容大纲: 1.函数基本语法与特性 2.参数与局部变量 3.返回值 4.递归 5.匿名函数lambda 6.函数式编程介绍 7.高阶函数 8.内置函数 1.函数基本语法与特性 函数的定义:函数是指将一 ...

  5. 深入理解javascript函数系列第三篇——属性和方法

    × 目录 [1]属性 [2]方法 前面的话 函数是javascript中的特殊的对象,可以拥有属性和方法,就像普通的对象拥有属性和方法一样.甚至可以用Function()构造函数来创建新的函数对象.本 ...

  6. 深入理解javascript函数系列第三篇

    前面的话 函数是javascript中特殊的对象,可以拥有属性和方法,就像普通的对象拥有属性和方法一样.甚至可以用Function()构造函数来创建新的函数对象.本文是深入理解javascript函数 ...

  7. DAX 第四篇:CALCULATE详解

    CALCULATE()函数是DAX中最复杂的函数,用于计算由指定过滤器修改的上下文中的表达式. CALCULATE(<expression>,<filter1>,<fil ...

  8. 【第三篇】ASP.NET MVC快速入门之安全策略(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

  9. 第三篇 功能实现(2) (Android学习笔记)

    第三篇 功能实现(2) ●Activity的四种启动模式 Activity的启动模式有四种,分别是standard.singleTop.singleTask和singleInstance. 在Andr ...

随机推荐

  1. ubuntu QT开发环境(三种方法安装Qt4.8,其中apt-get方法安装QT库最简单)good

    方法一 QT4.8.0库+QT Creator 2.4.1 特别声明:此方法极其耗时间,看电脑性能了.配置configure可减少编译时间 1.下载Qt .进入网址http://qt.nokia.co ...

  2. libjingler-0.6.2在windows和ubuntu 10.04下的编译(Google Talk)

    Libjingle版本:0.6.2 所需的资源:         gtest-1.6.0.zip         http://download.csdn.net/detail/cl_gamer/48 ...

  3. DataVeryLite入门教程(一) 配置篇

    DataVeryLite 是基于.net 4.0的数据库持久化ORM框架. 目前支持的数据库有Sqlserver,Mysql,Oracle,Db2,PostgreSql,Sqlite和Access. ...

  4. ASP.NET Web API 直到我膝盖中了一箭【1】基础篇

    蓦然回首,那些年,我竟然一直很二. 小时候,读武侠小说的时候,看到那些猪脚,常常会产生一种代入感,幻想自己也会遭遇某种奇遇,遇到悬崖跳下去是不是有本“武林秘笈”在等着?长大以后也是一样,多少人梦着醒着 ...

  5. Python实现按键精灵(二)-找图找色

    一.实现功能 判断在指定坐标范围内,是否存在相似度大于n的图片,并返回坐标. 二.基本思路 A=你需要寻找的图片 B=截取当前页面中指定范围的图片 利用opencv 判断A在B中的位置, 在该位置截取 ...

  6. Spring Boot:实现MyBatis动态数据源

    综合概述 在很多具体应用场景中,我们需要用到动态数据源的情况,比如多租户的场景,系统登录时需要根据用户信息切换到用户对应的数据库.又比如业务A要访问A数据库,业务B要访问B数据库等,都可以使用动态数据 ...

  7. Singleton and Prototype Bean Scope in Spring

    Scope描述的是Spring容器如何新建Bean的实例的. 1> Singleton: 一个Spring容器只有一个Bean的实例,此为Spring的默认配置,全容器共享一个实例. 2> ...

  8. kubernetes实战篇之helm完整示例

    系列目录 构建一个 Helm Chart 下面我们通过一个完整的示例来学习如何使用 Helm 创建.打包.分发.安装.升级及回退Kubernetes应用. 创建一个名为 mychart 的 Chart ...

  9. 在同一页面中显示多个echart图表

    整理了一下大概有两种做法来实现在同一个页面中显示多个echart图表,废话不说直接上代码. 在同一个echart对象中绘制多个图表 <!DOCTYPE html> <html lan ...

  10. k8s对象类资源格式

    k8s api仅接受及响应json格式的数据,同时,为了便于使用,它也允许用户提供yaml格式的post对象,但apiserver需要事先自行将其转换为json格式后方能提交.每个资源通常仅接受并返回 ...