我正试图在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;