在SSAS中计算从开始日期到今天的销售额



我正试图在ssas计算选项卡中编写查询,应产生以下结果。这就像一个从2016年2月1日到今天的YTD计算。我已经在管理工作室中编写了以下查询,但我需要将其转换为SSAS计算并将其写入计算选项卡。

WITH 
  MEMBER [Measures].[ytd Sales Target 2] AS 
    Sum
    (
        StrToMember
        (
          '[Sales Date].[Date].&[' + Format(Now(),'yyyy-') + '02-01T00:00:00]'
        )
      : 
        StrToMember
        (
              '[Sales Date].[Date].&[' + Format(Now(),'yyyy-') + Format(Now(),'MM-')
            + 
              Format
              (
                Now()
               ,'dd'
              )
          + 'T00:00:00]'
        )
     ,[Measures].[sales target]
    ) 
SELECT 
  [Measures].[ytd Sales Target 2] ON 0
FROM [sales];

应该像这样简单:

CREATE MEMBER CURRENTCUBE.[Measures].[ytd Sales Target 2]
AS
Sum
    (
        StrToMember
        (
          '[Sales Date].[Date].&[' + Format(Now(),'yyyy') + '-02-01T00:00:00]'
        )
      : 
        StrToMember
        (
              '[Sales Date].[Date].&[' + Format(Now(),'yyyy-MM-dd')+'T00:00:00]'
        )
     ,[Measures].[sales target]
    ),
VISIBLE = 1;  

这种方式不会考虑你的日期。但稍加改变,它就能"感知时间"。我添加了一个小检查,2月1日之前的日期被忽略。

CREATE MEMBER CURRENTCUBE.[Measures].[ytd Sales Target 2]
AS
iif(
    [Sales Date].[Date].CURRENTMEMBER.MEMBER_KEY < StrToMember('[Sales Date].[Date].&[' + Format(Now(),'yyyy') + '-02-01T00:00:00]').MEMBER_KEY
    ,NULL
    ,Sum (
        StrToMember
        (
          '[Sales Date].[Date].&[' + Format(Now(),'yyyy') + '-02-01T00:00:00]'
        )
      : 
        StrToMember
        (
              [Sales Date].[Date].CURRENTMEMBER
        )
     ,[Measures].[sales target]
    )
),
VISIBLE = 1;  

最新更新