Mondrian---Level排序的配置

方法一,直接配置需要排序的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>
   

猜你喜欢

转载自dsbjoe.iteye.com/blog/1103334
今日推荐