使用CrossJoin时进行MDX查询优化

时间:2016-04-17 06:58:43

标签: mdx cross-join

我正在编写一个MDX查询,其中我选择了一些测量,而选择我有一个where条件,我正在做一个交叉连接两个事实,一个是日期,另一个是唯一的ID,我传递的是2000个独特的id和查询大约需要20分钟才能执行并给出结果。

请在下面查询相同的

    SELECT {[Measures].[TOTAL1], [Measures].[TOTAL2], [Measures].[TOAL3]} ON  COLUMNS,
            " + " {TOPCOUNT(FILTER([ID].[Ids].MEMBERS, 
                            [ID].CurrentMember  > 0),
                              5,[Measures].[TOTAL])} " + "ON ROWS 
    FROM [CHARTS] 
    WHERE({[Date].&[2015-09-01 00:00:00.0]}*{[NUM].[1],[NUM].[10],"
                + "[NUM].[18],[NUM].[47],[NUM].[52],[NUM].[105],[NUM].[126],[NUM].[392],"
                + "[NUM].[588],[NUM].[656],[NUM].[995],[NUM].[1005],[NUM].[1010],[NUM].[1061]})";

没有字符串操作运算符(+)的直接mdx如下:

SELECT 
  {
    [Measures].[TOTAL1]
   ,[Measures].[TOTAL2]
   ,[Measures].[TOAL3]
  } ON COLUMNS
 ,{
    TopCount
    (
      Filter
      (
        [ID].[Ids].MEMBERS
       ,
        [ID].CurrentMember > 0
      )
     ,5
     ,[Measures].[TOTAL]
    )
  } ON ROWS
FROM [CHARTS]
WHERE 
    {[Date].&[2015-09-01 00:00:00.0]}
  * 
    {
      [NUM].[1]
     ,[NUM].[10]
     ,[NUM].[18]
     ,[NUM].[47]
     ,[NUM].[52]
     ,[NUM].[105]
     ,[NUM].[126]
     ,[NUM].[392]
     ,[NUM].[588]
     ,[NUM].[656]
     ,[NUM].[995]
     ,[NUM].[1005]
     ,[NUM].[1010]
     ,[NUM].[1061]
    };

请告诉我不同​​的性能优化技术。

1 个答案:

答案 0 :(得分:0)

如果你使用第三个排序参数,

TopCount会很慢 - 最好先订购数据,然后只用2个参数将预先订购的集合输入TopCount:

WITH 
  SET [S0] AS 
    Filter
    (
      [ID].[Ids].MEMBERS
     ,
      [ID].CurrentMember > 0
    ) 
  SET [S1] AS 
    Order
    (  
      [S0]
     ,[Measures].[TOTAL]
     ,BDESC
    ) 
  SET [S2] AS 
    TopCount
    (
      [S1]
     ,5
    ) 
SELECT 
  {
    [Measures].[TOTAL1]
   ,[Measures].[TOTAL2]
   ,[Measures].[TOAL3]
  } ON COLUMNS
 ,[S2] ON ROWS
FROM [CHARTS]
WHERE 
    {[Date].&[2015-09-01 00:00:00.0]}
  * 
    {
      [NUM].[1]
     ,[NUM].[10]
     ,[NUM].[18]
     ,[NUM].[47]
     ,[NUM].[52]
     ,[NUM].[105]
     ,[NUM].[126]
     ,[NUM].[392]
     ,[NUM].[588]
     ,[NUM].[656]
     ,[NUM].[995]
     ,[NUM].[1005]
     ,[NUM].[1010]
     ,[NUM].[1061]
    };