Mondrian---Level排序的配置

本文探讨了在数据处理中,如何通过配置直接排序列或使用表达式来实现排序的方法,特别关注排序方向的实现技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方法一,直接配置需要排序的ordinalColumn ,缺点是需要增加一个排序的列,在外置维度数据量不大且更新不是很频繁的时候相对适用

       <Dimension name="CHARGE_TODAY" foreignKey="FACT_KEY">
            <Hierarchy hasAll="true" allMemberName="ALL" primaryKey="DIM_KEY">
                <Table name="DIM_TABLE_NAME"></Table>

                <Level name="LEVEL_NAME" column="LEVEL_COLUMN" ordinalColumn

="ORDINAL_COLUMN_NAME"/>


            </Hierarchy>
        </Dimension>
 

方法二,有的时候排列的列可能是个表达式,可以用如下方式配置。由于没有提供排序方向的配置,这里为了让结果按照LogDay降序排列,取巧用Sysdate-logDay的方式变相实现,会不会很挫?

       <Dimension name="LOGDAY">
            <Hierarchy hasAll="true">
                <Level name="LOGDAY " column="LOGDAY" uniqueMembers="true" type="Date">

                    <OrdinalExpression>
                        <SQL dialect="generic">
                            SYSDATE - LOGDAY
                        </SQL>
                    </OrdinalExpression>


                </Level>
                <Level name="LOGHOUR " column="LOGHOUR" uniqueMembers="true" type="Integer"/>
            </Hierarchy>
        </Dimension>
   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值