Mondrian系列(五)-深入维度、层次和级别(4)-维度退化和内联表

1.维度退化

维度退化是指对于简单的维度来说,不创建自己的维表,例如,下面的事实表:

product_idtime_idpayment_methodcustomer_idstore_iditem_countdollars
5520040106Credit123223$3.54
7820040106Cash89221$20.00
19920040107ATM3222$2.99
5520040106Cash122221$1.18

对于其中的维度支付方式,假设我们创建了一个维表,这个维表几乎是没有意义的。如果单独增加了这样一个维表,那么可能会导致一定的连接成本。(对于这个问题,我持有不同的看法,例如当这个维度是可被复用时,则这个维表是有意义的

可以创建一个退化维度,声明一个不包括表的维度,mondrian会假设列来自事实表。看下面的例子:


   
   

       
           
           
       
   
   

在上面的实例中,因为没有join,Dimension维度的foreignKey属性不需要设置,Hierarchy元素没有

2.内联表

构造允许你在schema文件中定义数据集。必须声明列的名字,列的类型,以及一系列的行。作为

子元素或primaryKey属性。 ,必须提供唯一的别名指向数据集。如下面的例子:


   
       
           
               
               
           
           
               
                    1
                    High
               
               
                    2
                    Medium
               
               
                    2
                    Low
               
           
       
       
   

这和你的数据库中有下面的表是一样的效果。

iddesc
1High
2Medium
3Low

要指定某个列NULL值,对那个列忽略 ,列的值默认为空。

3.估计Level的势

元素允许指定可选的参数 "approxRowCount",指定这个参数可以改善性能,通过减少需要决定的level,层次和维度的势。通过连接到XMLA的Mondrian,可能会产生较大的影响。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值