MDX的学习

MDX(MultiDimensionalExpressions)语句:多维对象与数据的定义和操作,并赋予用户表现查询结果的能力。
每个mdx查询都要求有数据请求(select子句),起始点(from子句),和筛选(where子句)

使用方式
1.MDX查询语句
查询所需要的数据
2.MDX表达式
定制需要的指标
3.MDX脚本
指定流程由SQL执行生成自定义的效果

MDX中的相关概念
1.多维数据集
2.度量值(量度)
3.维度
4.维度的层次结构
5.维度的级别
6.成员(Member):指的是维度树上的一个节点,这里有一点需要指出,量度也是一个特殊的维度,所以对于普通维度上的Member可以有以下几种表示方法:[Customer]或[Time].[1996]等。
标识符:[]
7.元组(Tuple):是由若干个Members组成,对于一个Tuple而言至少有一个维度,多则不限,顺序无关。
标识符:()
例子:1.([Region].[USA])
2.([product].[computers],[time].[2008])
8.集(Set)
同一维度上若干个Members的集合,或者是若干个Tuples的集合,但这里有一个地方需要注意。
标识符:{}
例子:
1.{[time].[2008],[time].[2009],[time].[2000]},这里Set是由同一维度的若干个Member组成。
2.{([computer],[usa]),([mobile],[china])},这个set是由两个Tuples组成,这里大家可以看到,在第一个Tuple当中,第一个Member是名为computer的产品,所以后面的Tuple的第一个Member也必须是一个产品。第一个Tuple的第2个Member是国家,
第二个Tuple的第2个Member是国家。

基本语法:
一个标准的MDX查询语句就是由我们前面介绍的MDX的三个基本对象构成,也就是Member,Tuple,Set

简单MDX查询示例
想象一个简单的带有时间,销售地点和度量3个维度的多维数据集,该多维数据集的名称为销售额(即SALES).
其中度量包括销售额和成本。
select {[MEASURES].[DOLLAR SALES],[MEASURES].[UNIT SALES]} ON COLUMNS,
{[TIME].[2005].[Q1],[TIME].[2005].[Q2]} ON ROWS
FROM [SALES]
WHERE ([CUSTOMER].[MA])

 MDX查询的结果本身是一个网格,本质上是另一个多维数据集。下面将这个简单的查询拆开来仔细研究。
 关键字SELECT后带需要检索内容的子句。
 
   关键字ON和轴的名称一起使用,以指定数据库的维度显示位置。该示例查询将度量显示为列,将时间段显示为行。
   
   MDX用大括号{}引用来自某个特点维度或者多个维度的一组元素。这个简单的查询在其两个轴中的每一个上都只有一个维度(度量维度和时间维度)。元素间用逗号隔开。元素名称用方括号引用,并且不同组成部分之间用点号分隔。
   
   MDX能够在FROM子句指明用于查询数据库的多维数据集。这与SQL中的FROM子句类似。
   where子句指定在列或行(或者其他轴上)不出现的多维数据集其他维度的成员。如果不对某个维度指定一个成员,MDX将使用默认成员。WHERE子句是可选的。
   提示:MDX不是大小写敏感的,可以随心所欲的混用字母大小写。

MDX中的简单函数和操作符
1.逗号(,)与冒号(:)
可以通过枚举元素并用逗号来隔开构造一个集,例如上面示例中用到的例子。
{[TIME].[2005].[Q1],[TIME].[2005].[Q2]}
该表达式产生一个包含2005年第一季度和第二季度的集。
冒号用同一级别的两个成员作为端点,来表示这两个端点间的所有成员(与EXCEL中的指定单元格范围的用法类似).在冒号两边可以是相同的成员,表示集中只有一个成员。例如:
{[TIME].[2005].[SEP]:[TIME].[2006].[MAR]}
该表达式表示从2005年9月到2006年3月的所有月份。

  1. .MEMBERS 获取所有成员
    无论用于检索,还是作为更复杂的操作的基础,获得一个维度,层次结构或者级别的成员的集是非常普遍的操作。维度,层次结构或者级别放置在.MEMBERS操作符的左边,可以返回由该元数据范围内所有成员构成的集。
    例如:
    [TIME].[MONTHS].MEMBERS
    该表达式返回时间维度下的月这一级别的所有成员(即所有月份)

  2. .PREMEMBER获取指定成员的前一个成员

  3. .NEXTMEMBER获取指定成员的后一个成员

  4. 使用.CHILDREN获得一个成员的子成员
    另外一个常用的查询时获得一个成员的子成员。这么做的目的可能是执行一个向下钻的操作,或者为了方便的获得基于一个共同父成员的范围内的成员。例如:
    [TIME].[YEARS].[2005].CHILDREN
    该表达式返回2005年的所有的孩子(即2005年的所有月份)

  5. .FIRSTCHILD 获取指定成员的第一个子成员

  6. .LASTCHILD 获取指定成员的最后一个子成员

更多基本词汇
1.DESCENDANTS()获取一个成员的后代成员
2.FILER()过滤
3.ORDER() 排序
4..CURRENTMEMBER获取当前成员
DIMENSION.CURRENTMEMBER
返回该维度的当前成员

  1. .PARENT获取指定成员的父对象成员
    MEMBER.PARENT
    返回对给定成员的父对象成员
    6.NONEMPTY去除空切片
    在一个多维空间中,数据稀疏现象很常见。MDX中提供了从查询的结果中移除完全为空的切片的方法,那就是使用NONEMPTY关键字。
    去除空切片需要做的仅仅是在待移除空切片的轴前面加上NONEMPTY关键字。NONEMPT可以用在任何轴,维度和元组上。
    7.去年同期的引用和计算
    一个经常会用到的计算是查询一年前同一时期的数据,或者上一个季度同一时期和上周同一天的数据。可以使用PARALLELPERIOD()函数。
    语法:
    PARALLELPERIOD(LEVEL,INDEX,MEMBER)
    parallelperiod(level,index,member)
    例如:
    parallelperiod([YEARS],1,[MAY2006])
    将返回[MAY2005]
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容