MDX - icCube - 如何与其他聚合一起获得 DYNAMIC topcount/toppercent?

标签 mdx olap iccube

使用以下 mdx,我能够动态检索正确的数据。

create CATEGORY MEMBER [Stats].[Top].[All Etabs].[Top 5 Etablissements] 
    as topcount( [Etablissement].[Etablissement].[Etablissement].allMEMBERS, 5, [Measures].[Nbsejours]),ADD_CHILDREN=true

create CATEGORY MEMBER [Stats].[Top].[All Etabs].[Autres Etablissements (>5)] 
    as Except([Etablissement].[Etablissement].[Etablissement].members,  TopCount( [Etablissement].[Etablissement].[Etablissement].MEMBERS, 5, [Measures].[Nbsejours])),ADD_CHILDREN=false

create dynamic set [Top 5 & Others] 
    as {[Stats].[Top].[Top 5 Etablissements], [Stats].[Top].[Autres Etablissements (>5)]}

Select {[Measures].[NbSejours]} on 0,
nonempty ([Top 5 & Others]) on 1
From //[Cube]
( SELECT { {[Geographique].[Zone].[All-M].&[1006]} } ON 0 FROM [Cube])

但是,topCount 本身并不是动态的。在这个例子中,前 5 个 etablissement 永远不会改变,只有值会改变......

有没有办法通过动态 topCount/topPercent 来实现? 发送, 伯特兰。

最佳答案

Categories (*) 还没有动态标志,因此无法定义一个类别,该类别将针对每个 MDX 请求计算一次,因为它发生在一个集合中。

所以它会更像(注意我使用了 SubCubeComplement 很多 - 可能真的很多 - 更快)

create dynamic set [Top 5] as 
      topcount( [Etablissement].[Etablissement].[Etablissement].members, 5, [Measures].[Nbsejours])

*** End script ***

WITH 
 CATEGORY HIERARCHY [Stats].[Top], DEFAULT_MEMBER_NAME = "All Etabs"
 CATEGORY MEMBER [Stats].[Top].[All Etabs].[Top 5 Etablissements] as 
      [Top 5],ADD_CHILDREN=true
 CATEGORY MEMBER [Stats].[Top].[All Etabs].[Autres Etablissements (>5)] as
      SubCubeComplement([Top 5]),ADD_CHILDREN=false
SELECT
  {[Measures].[NbSejours]} on 0,
  { [Stats].[Top].[Top 5 Etablissements], 
    [Stats].[Top].[Autres Etablissements (>5)] } on 1
From [Cube]

(*) 对于不习惯 icCube 的人来说,类别是一种将"new"成员定义为一组成员的方式(它们可能具有不同的维度)。这确保对于复杂的计算、具有多对多关系的模式,可以正确计算值。否则,确保计算正确性可能是一场噩梦。

关于MDX - icCube - 如何与其他聚合一起获得 DYNAMIC topcount/toppercent?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28044671/

相关文章:

mdx - Pentaho Mondrian MDX - 删除父标题

ssas - 非空先前值 - MDX

sql-server - 如何评估 MDX 在 OLAP 处理中的性能

mdx - icCube 中的 format_string 不格式化空值

Javascript同步请求icCube

sql - 使用 MDX 期间的最后一个非空子项

ssas - MDX 查询 - 如何使用成员属性?

java - Mondrian Olap 向下钻取算法

ssas - OLAP - 包括计算径流三角形、样本数据和立方体 (PostgreSQL/Mondrian)

java - 找不到 icCube 驱动程序 : org. postgresql.Driver