简单MDX中冒号(:)的使用说明

        在一本书上看到了在mdx中冒号的使用说明,于是自己测试了一下并将其中较重要的内容整理成笔记。

     

在每个维度的每个级别上,该级别的成员按照特殊的顺序排列(通常按照成员键或者各种名称排列)。当这个排列顺序有某种意义时,将来自同一级别的成员作为端点,并用冒号隔开,这表示“这两个成员及其中间的所有成员”,这样按照指定的顺序排列的成员构成一个“集”。例如下面的语句查询的是从 2007Q2 季度到 2008Q1 季度数码产品的总销售额 .MDX 语句如下:

 

SELECT { [Product Category].[All Products].[Digital Products] } ON COLUMNS ,

{[Sale Time].[All Years].[2007].[Q2]: [Sale Time].[All Years].[2008].[Q1] } ON ROWS 

FROM [Sales]

WHERE ( [Measures].[Total Sale])  

( 效果图如上传的图1.bmp。)

 

当数据库定义的顺序和现实中的顺序(如时间顺序)相关时,一般采用上面的方式建立集。冒号用同一级别的两个成员作为端点。在冒号两边 可以是相同的成员,表示集中只有一个成员。

说明:软件差异

Analysis services

    在 Analysis Services 中,按照数据库中的顺序,无论冒号左边的成员在冒号右边的前面还是后面,产生的集都包含着两个成员之间的所有成员。即,下面的两条语句返回完全相同的集。

{[Sale Time].[All Years].[2007].[Q2]: [Sale Time].[All Years].[2008].[Q1] }

{[Sale Time].[All Years].[2008].[Q1][Sale Time].[All Years].[2007].[Q2] }

 

     Essbase 中,集的元素从冒号左边成员开始,到右边成员结束。下面的语句依次返回 4 季度, 3 季度, 2 季度和 1 季度:

 

{[Sale Time].[All Years].[2007].[Q4] [Sale Time].[All Years].[2007].[Q1] }

 

而在 Analysis Services 中则从上到下依次返回 1 季度, 2 季度, 3 季度, 4 季度。

 

 (效果图如上传的图2.bmp。)

 


By the way, 供大家交流Pentaho的圈子,里面可以共享有关pentahoBI平台学习的资料,期待您的加入! http://pentahofrends.group.iteye.com/group/share

 

MDICT的文件制作工具 转换程序支持格式: 1) 扩展的SugarDict格式: 每个项目(词条)一行,缺省最大为32K. 格式为: 关键字 解释(就是关键字和解释之间用空格分开) 关键字: 可以是大小写的组合, 每个单词的最大长度是255个字符。 关键字和解释的'_', '^'在转换后会被替换成空格和回车 例子: break_through /'bri:k_MQru:/ ^v. 突破^n. 突破 good ^adj.好^adj.贼好^adj.好得不得了 2) KDict解码后的tab格式 每个条目一行,关键字和解释之间用"tab"分隔. 其的"\n"会被转换成换行 例如: good adj.好\nadj.贼好\nadj.好得不得了 3) MDict的html格式 每个项目两行 第一行是关键字 第二行开始是正文, 这里的正文应该包括关键字。可以使用html的标记(不要包含 , 这个程序会自动加上, 另注意在转换时要指明源数据为html). 如果需要显示音标的话,可以利用html指定字体就可以显示了。(参见下面的例子) 正文结束后必须用一行表示结束 例子: Whole whole (hol,hJl; houl) 在html连接到其它关键字的方法: key 其key是关键字,section是对应关键字页面的section名称. 4) MDict的紧凑型html格式(Compat Html) 这个格式由两个文件组成,正文文件格式基本和2)一样,但在正文里可以使用记号。另外 一个是记号文件。 记号文件的格式: 由多个记号定义组成,每个记号定义有3行 第一行: 记号的名称(只能用数字,必须大于0,最大不超过255) 第二行: 开始字符串(可以为空) 第三行: 结束字符串(可以为空) 使用时在正文里使用`记号`(键盘左上角的那个符号)就会将后续的文字直到下一个记号前的文 字用记号定义的开始字符串和结束字符串括起来。正文里如果需要显示` 则用"`"表示。内 码应该和正文的一样(例如正文如果是用Unicode的话,记号文件也应该用Unicode) 例如: 记号文件: 1 2 3 正文文件: whole `1`whole`s`2``3`(hol,hJl; houl) 最后在显示的时候就会被替换成 whole&#%96;s(hol,hJl; houl) 备注: 如果你的数据里含有国际音标,建议使用Unicode格式 (请参考http://www.phon.ucl.ac.uk/home/wells/ipa-unicode.htm) 将音标用对应的Unicode进行表示。这样只要用户装有支持IPA的字体文件就能够显示音标。 (Windows里的Lucida Console就包含有IPA对应的字体)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值