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

一,筛选上下文的构成

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

1,交叉过滤器

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

2,查询上下文

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

3,外部切片器

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

二,清除过滤器

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

1,ALL

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

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

2,ALLCROSSFILTERED

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

  1. ALLCROSSFILTERED(<table>)

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

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

3,ALLEXCEPT

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

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

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

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

4,ALLSELECTED

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

  1. 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。
  1. SalesRateBySelectedColors = DIVIDE(CALCULATE(SUM( FactSales[SalesAmount]))*1.0, CALCULATE(SUM(FactSales[SalesAmount]),ALLSELECTED()))

5,REMOVEFILTERS

移除过滤器,不会返回表

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

三,添加过滤器

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

  1. FILTER(<table>,<filter>)

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

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

四,直接过滤和交叉过滤

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

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

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

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

  1. direct_filtered_colors = COUNTROWS((FILTERS(DimProduct[Color])))
  2. cross_filtered_distinct_colors = COUNTROWS((DISTINCT(DimProduct[Color])))
  3. cross_filtered_values_colors = COUNTROWS((VALUES(DimProduct[Color])))

结果分析:

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

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

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

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

  1. ISCROSSFILTERED(<columnName>)
  2. ISFILTERED(<columnName>)

2,返回过滤的唯一值

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

  1. FILTERS(<columnName>)

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

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

DISTINCT 和 VALUES函数的定义是:

  1. DISTINCT(<table | column>)
  2. VALUES(<Table | Column>)

3,检查唯一

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

  1. HASONEFILTER(<columnName>)

该函数等价于:

  1. COUNTROWS(FILTERS(<columnName>)) =

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

  1. HASONEVALUE(<columnName>)

该函数等价于:

  1. COUNTROWS(VALUES(<columnName>)) =

4,SELECTEDVALUE

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

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

该函数等价于:

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

五,关联值

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

  1. RELATED(<column>)

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

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

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

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

  1. 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. IntelliJ IDEA的jsp中内置对象方法无法被解析的解决办法

    主要原因是因为缺乏依赖 可以通过添加依赖的方式 导入servlet-api.jar,jsp-api.jar,tomcat-api.jar 这三个jar即可 这三个jar在tomcat的lib目录下有 ...

  2. cStor云存储、cProc云处理、cVideo云视频、cTrans云传输,云创个人网盘

    http://www.cstor.cn,微信公众号:cstor_cn.      云创大数据是国际上云计算产品线齐全的企业之一,针对爆炸式增长的大数据需求,研发了自主知识产权的cStor云存储.cPr ...

  3. 浅谈网络爬虫爬js动态加载网页(一)

    由于别的项目组在做舆情的预言项目,我手头正好没有什么项目,突然心血来潮想研究一下爬虫.分析的简单原型.网上查查这方面的资料还真是多,眼睛都看花了.搜了搜对于我这种新手来说,想做一个简单的爬虫程序,所以 ...

  4. 在Mac OSX下使用ssh建立隧道(在Windows下建立隧道可以使用putty,其间会用到ppk文件)

    在Windows下建立隧道可以使用putty,其间会用到ppk文件.在Mac OSX下,同样的功能可以用ssh命令实现.具体是: ssh -D 8088 -Nf user@ip -i myppk.ss ...

  5. Struts2 学习笔记(概述)

    Struts2 学习笔记 2015年3月7日11:02:55 MVC思想 Strust2的MVC对应关系如下: 在MVC三个模块当中,struts2对应关系如下: Model: 负责封装应用的状态,并 ...

  6. Redis EXISTS命令耗时过长case排查

    一.背景 redis慢日志分析平台上线后,随便看了一下,发现onestore使用的缓存集群,存在大量的EXISTS命令慢查询的情况: 平均每个EXISTS命令需要13ms,最大耗时近20ms.这个结果 ...

  7. SYN4201型 同步分频钟

    SYN4201型 同步分频钟 产品概述 SYN4201型同步分频钟是由西安同步电子科技有限公司精心设计.自行研发生产的一款高精度分频时钟,对输入的8路10MHz正弦信号分别进行同步分频处理,相应的输出 ...

  8. SYN5301型 毫秒表时间检定仪

       SYN5301型  毫秒表时间检定仪 频率记录仪时间记录仪时间频率信号的精密测量使用说明视频链接; http://www.syn029.com/h-pd-76-0_310_6_-1.html 请 ...

  9. Python连载12-shutil模块

    一.shutil模块 1.函数:copy() (1)用法:复制文件0 (2)格式:copy(来源路径,目标路径) (3)返回值:返回目标路径 (4)注意:拷贝的同时可以给文件重命名 source_pa ...

  10. python下SQLAlchemy的使用

    SQLAlchemy是python中orm常用的框架.支持各种主流的数据库,如SQLite.MySQL.Postgres.Oracle.MS-SQL.SQLServer 和 Firebird. 在安装 ...