MDX Cookbook 04 - 在集合中实现 NOT IN 逻辑 (Minus, Except, Filter 等符号和函数的使用)
有时需要从一些查询结果里排除掉一些成员,当然平常情况下可以通过 MDX 查询中的 WHERE 条件即 Slicer 切片来完成,同样的这里显示的是如何在切片中排除掉一些成员。
先看这一个查询 -
SELECT { [Measures].[Reseller Order Count] } ON 0,
NON EMPTY {[Promotion].[Promotion].MEMBERS }
DIMENSION PROPERTIES [Promotion].[Promotion].[Discount Percent]
ON 1
FROM [Adventure Works]

上面的查询返回了12个 Promotion 成员,DIMNSION PROPERTIES 关键字用来获取有关成员的属性信息 - Discount Percent。
可以双击成员查看它们的属性信息,例如双击 No Discount 成员可以看到它的成员属性 -

下面我们要做的就是排除掉 [Promotion].[Promotion].[Discount Percent] 成员属性值为0,2 和 5 的成员。


添加 WHERE 条件
SELECT { [Measures].[Reseller Order Count] } ON 0,
NON EMPTY {[Promotion].[Promotion].MEMBERS }
DIMENSION PROPERTIES [Promotion].[Promotion].[Discount Percent]
ON 1
FROM [Adventure Works]
WHERE ( -
{
[Promotion].[Discount Percent].&[],
[Promotion].[Discount Percent].&[2.E-2],
[Promotion].[Discount Percent].&[5.E-2]
}
)
打开 Promotion 维度找到 Discount Percent 然后将 0,2,5 三个值拖放过来,最后用 - 号表示要排除

最终 'No Discount', 'Volume Discount 11 to 14', 'Volumn Discount 15 to 24' 这几个成员就被排除掉了。

在最开始的查询中并没有使用任何的切片 Slicer 去过滤层次结构轴上的任何成员,但是也不需要显示的写出来,因为 SSAS 有一套元组的自动填充规则来将局部元组补充完全。通过 WHERE 条件我们使用到了切片的概念,它实则就是在层次结构轴上排除掉了'No Discount', 'Volumn Discount 11 to 14', 'Volumn Discount 15 to 24' 这几个成员,那么整个 Cube 空间的形成自然也将排除掉由这几个成员与其它层次结构轴构成的轴空间。
我们也可以使用 Except 函数来实现同样的结果:
SELECT { [Measures].[Reseller Order Count] } ON 0,
NON EMPTY {[Promotion].[Promotion].MEMBERS }
DIMENSION PROPERTIES [Promotion].[Promotion].[Discount Percent]
ON 1
FROM [Adventure Works]
WHERE EXCEPT(
{[Promotion].[Discount Percent].[Discount Percent].MEMBERS},
{
[Promotion].[Discount Percent].&[],
[Promotion].[Discount Percent].&[2.E-2],
[Promotion].[Discount Percent].&[5.E-2]
}
)
EXCEPT ({SET 1},{SET 2}) 函数的作用就是取得 SET 1 没有在 SET 2 中出现的那部分成员形成的集合,注意返回的是 SET 1 中的成员。
在这个例子中,Discount Percent 属性中定义了 MemberValue 值,因此还可以通过 Filter 函数来实现 NOT IN 的逻辑。
SELECT { [Measures].[Reseller Order Count] } ON 0,
NON EMPTY {[Promotion].[Promotion].MEMBERS }
DIMENSION PROPERTIES [Promotion].[Promotion].[Discount Percent] ON 1
FROM [Adventure Works]
WHERE
(
{ FILTER(
[Promotion].[Discount Percent].[Discount Percent].MEMBERS,
[Promotion].[Discount Percent].CurrentMember.MemberValue >= 0.1
)
}
)

但是要注意,这里在 FILTER 中的条件表达式的前提是 [Promotion].[Discount Percent].CurrentMember.MemberValue 中的值确实是连续的,如果不是连续的已经排过序的值,那么就不可以使用 Filter 来实现这个例子。
其它 BI 系列文章请参看 BI 系列随笔列表 (SSIS, SSRS, SSAS, MDX, SQL Server)
MDX Cookbook 04 - 在集合中实现 NOT IN 逻辑 (Minus, Except, Filter 等符号和函数的使用)的更多相关文章
- MDX Cookbook 08 - 基于集合上的迭代递归
递归的应用有时是非常重要的,特别在迭代一个集合的时候.为什么这么说呢?原因在于迭代在MDX中的使用是基于集合函数的,像 GENERATE() 它们都需要遍历整个集合.但是如果这个集合非常的庞大,我们仅 ...
- MDX Cookbook 01 - Skipping Axis 合理使用空的 SET 集合获取全部层次结构成员
假设我们只想显示一些与数据没有任何关联的维度成员信息,并且希望它们能够以行集的形式来显示,那么在 MDX 中就应该直接显示 ROWS AXIS (1) 并且忽略掉 COLUMNS AXIS(0).比 ...
- List集合中元素排序
应用场景: 在开发中经常遇到要对List<Object>集合进行排序,并且是根据集合中的对象的某个属性来进行排序 --------以下就此做出的解决方案 public static ...
- MDX Cookbook 06 - GENERATE 循环遍历
有时候需要从集合中取出特定的成员但是又不能执行遍历操作,这个时候就可以使用 GENERATE 函数来解决这个问题. 根据地区查询每年的销售额 - SELECT NON EMPTY { , NON EM ...
- Java分享笔记:使用keySet方法获取Map集合中的元素
/*--------------------------- Map集合中利用keySet方法获取所有的元素值: ....keySet方法:将Map中的所有key值存入到Set集合中, ....利用Se ...
- 【DDD/CQRS/微服务架构案例】在Ubuntu 14.04.4 LTS中运行WeText项目的服务端
在<WeText项目:一个基于.NET实现的DDD.CQRS与微服务架构的演示案例>文章中,我介绍了自己用Visual Studio 2015(C# 6.0 with .NET Frame ...
- 判断IEnumerable<T>集合中是否包含有T对象
比如,有角色集合中,只有用户创建有角色,才出现“分配”铵钮.反之,隐藏. IEnumerable有一个方法,叫Any:
- java范型集合中的成员排序
范型集合中的类是JsonObject,不是自定义类,如果是自定义类就直接取要比较的字段值. ArrayList<JSONObject> TList = new ArrayList<J ...
- POI完美解析Excel数据到对象集合中(可用于将EXCEL数据导入到数据库)
实现思路: 1.获取WorkBook对象,在这里使用WorkbookFactory.create(is); // 这种方式解析Excel.2003/2007/2010都没问题: 2.对行数据进行解析 ...
随机推荐
- python+selenium八:Alert弹窗
此弹窗是浏览器自带的弹窗,不是html中的元素 from selenium import webdriverfrom selenium.webdriver.common.action_chains i ...
- python 全栈开发,Day28(复习,os模块,导入模块import和from)
一.复习 collections 增加了一些扩展数据类型 :namedtuple orderdict defaltdict队列和栈time 时间 三种格式 : 时间戳 结构化 字符串random 随机 ...
- Python 时间复杂度
引用自:https://www.cnblogs.com/sch01ar/p/8552295.html
- Python contains
一.__contains__ 判断字符串中是否包含相应的字符.
- 手动部署 kubernetes 1.9 记录
前言 目前 kubernetes 正式版本已经到1.10版本.因为前面有大佬(漠然)已经采完坑,所以自己也试着部署 kubernetes 1.9 体验下该版本的新特性.对于前面部署的 kubernet ...
- 080 HBase的属性
一:基本属性 1.查看属性 2.解释属性 NAME:列簇名 BLOOMFILTER:布隆过滤器,用于对storefile的过滤 共有三种类型: ROW:行健过滤 ROWCOL:行列过滤 NONE:无 ...
- @ConfigurationProperties和@Value 注入
我这里使用的Spring Boot 2.0.1 版本 配置文件是 yml 格式文件 @ConfigurationProperties 在yml配置文件中: 在实体类中: 重点是实体类上的两个注解: @ ...
- IPv6升级改造包括什么?
关于IPv6技术升级具体做了什么,在我脑海里只是更换了域名解析的IP而已,所以找了这篇文章,帮助初步解惑. 原文地址:https://www.maczd.com/post/web-ipv6-upgra ...
- 闪烁的LED灯
/* Main.c file generated by New Project wizard * * Created: 周五 五月 5 2017 * Processor: 80C31 * Compil ...
- 牛客网NOIP赛前集训营-提高组(第四场)游记
牛客网NOIP赛前集训营-提高组(第四场)游记 动态点分治 题目大意: \(T(t\le10000)\)组询问,求\([l,r]\)中\(k(l,r,k<2^{63})\)的非负整数次幂的数的个 ...