MDX 计算速度 - 当前成员

  • 本文关键字:成员 计算 速度 MDX mdx
  • 更新时间 :
  • 英文 :


我仍在掌握MDX,我正在寻求一些帮助。这是我的 MDX 查询:

 CREATE MEMBER CURRENTCUBE.[Measures].[Fake]
   AS 
   IIF(
    (
      (
        [Sales Data].[Ship-to No].CurrentMember
       ,[Sales Data].[Price Type].&[Core]
       ,[Measures].[Sales - Local Currency]
      ) 
    / (
        [Sales Data].[Ship-to No].CurrentMember,
        [Sales Data].[Price Type].[(All)].[ALL],
        [Measures].[Sales - Local Currency]
      )
    ) > 0.9 
  ,1 
  ,NULL
  ), 
VISIBLE = 1; 
CREATE MEMBER CURRENTCUBE.[Measures].[Test Calc]
  AS 
  SUM(
     Descendants(
       [Sales Data].[Ship-to No].CurrentMember
      ,[Sales Data].[Ship-to No].[Ship-to No]
     ),
    [Measures].[Fake]
  ), 
VISIBLE = 1; 

SalesData 是事实数据表,基本计算是计算销售额超过价格类型"核心"的 90% 的客户数量。

查询目前大约需要 5 秒才能完成,但我认为如果我不使用 CurrentMember http://sqlblog.com/blogs/mosha/archive/2008/07/29/product-volatility-optimizing-mdx-with-mdx-studio.aspx

但是我不知道从哪里开始改变这一点,谁能帮我提高效率?

如果从第一个度量中删除当前成员,它有什么区别吗?

 CREATE MEMBER CURRENTCUBE.[Measures].[Fake]
   AS 
   IIF(
    (
      (
        [Sales Data].[Price Type].&[Core]
       ,[Measures].[Sales - Local Currency]
      ) 
    / (
        [Sales Data].[Price Type].[(All)].[ALL],
        [Measures].[Sales - Local Currency]
      )
    ) > 0.9 
  ,1 
  ,NULL
  ), 
VISIBLE = 1; 

对于您在第二个措施中使用的当前成员,也许现有就足够了:

CREATE MEMBER CURRENTCUBE.[Measures].[Test Calc]
  AS 
  SUM(
    EXISTING [Sales Data].[Ship-to No].[Ship-to No].MEMBERS
    ,[Measures].[Fake]
  ), 
VISIBLE = 1;

最新更新