How to query 3 month running average from SSAS Multidimensional Cube (MDX) for each date? -


i have ssas multidimensional cube , need query 3 month running average each day in date range.

for example, 2016-04-25 must data from 2016-01-01 2016-03-31. can't use query (because don't know how days must lag till previous month):

with member [measures].[salesamount 3m average] ( sum(     ([date].[date].currentmember.lag(90) :     ([date].[date].currentmember.lag(1),     [measures].[salesamount]     ) ) 

i guess need use ancestor function month , use lag month granularity.

ok, let's try one:

with member [measures].[salesamount 3m average] ( sum(     (ancestor ( [date].[date].currentmember, [date].[month] )).lag(3) :     (ancestor ( [date].[date].currentmember, [date].[month] )).lag(1),     [measures].[salesamount]     ) ) select { [measures].[salesamount 3m average] } on columns, { [date].[date].&[2016-01-01t00:00:00] : [date].[date].&[2016-02-28t00:00:00]} on rows [cube] 

unfortunately, query doesn't work (returns null).

how solve problem?

updated: ok, tryed query member caption:

member [measures].[test] ( (ancestor      (   [date].[date].currentmember,          [date].[date].[month] )     ).item(0).member_caption ) 

and i'm getting not month caption, date(day) - same date [date].[date].currentmember.

then tryed queries:

--first try member [measures].[test] ( isancestor([date].[date].currentmember, [date].[month].&[2016-05-01t00:00:00]) )   --second try member [measures].[test] ( isancestor([date].[date].currentmember, [date].[date].[month].&[2016-05-01t00:00:00]) )   --third try member [measures].[test] ( isancestor([date].[date].currentmember, [date].[year -  quarter -  month -  date].[month].&[2016-05-01t00:00:00]) )  

in queries result "false". so, month member not ancestor date members??? i'm confused.

my date dimension looks this:

enter image description here

update 2:

member [measures].[test] ( (ancestor      (   [date].[date].currentmember,          1 )     ).member_caption ) 

returns: all

your code seems fine. i'd add item(0) in couple of places make things more obvious shouldn't change much

with    member [measures].[salesamount 3m average]      sum     (         ancestor         (           [date].[calendar].currentmember          ,[date].[calendar].[month]         ).item(0).lag(3)       :          ancestor         (           [date].[calendar].currentmember          ,[date].[calendar].[month]         ).item(0).lag(1)      ,[measures].[internet sales amount]     )  select    {[measures].[salesamount 3m average]} on columns  ,{       [date].[calendar].[date].&[20060222]     :        [date].[calendar].[date].&[20060722]   } on rows [adventure works]; 

returns this:

enter image description here

check level expressions correct:

[date].[date] ? 

and

[date].[month] ? 

also further test return?

with    member [measures].[test1]      ancestor     (       [date].[date].currentmember      ,[date].[month]     ).item(0).lag(3).member_caption    member [measures].[test2]      ancestor     (       [date].[date].currentmember      ,[date].[month]     ).item(0).lag(1).member_caption  select    {     [measures].[test1]    ,[measures].[test2]   } on columns  ,{       [date].[date].&[2016-01-01t00:00:00]     :        [date].[date].&[2016-02-28t00:00:00]   } on rows [cube]; 

ancestor function between different levels of same hierarchy ie:

enter image description here

what means [date].[date] , [date].[month] not related via ancestor. try this:

with  member [measures].[salesamount 3m average]   (     sum(       ancestor (           [date].[year -  quarter -  month -  date].currentmember,          [date].[year -  quarter -  month -  date].[month] ).lag(3)         :       ancestor(           [date].[year -  quarter -  month -  date].currentmember         ,[date].[year -  quarter -  month -  date].[month] ).lag(1)       ,[measures].[salesamount]     )   ) select  { [measures].[salesamount 3m average] } on columns, {    [date].[year -  quarter -  month -  date].[date].&[2016-01-01t00:00:00]  : [date].[year -  quarter -  month -  date].[date].&[2016-02-28t00:00:00] //i suspect above 2 lines can replaced following: //  [date].[date].&[2016-01-01t00:00:00] //: [date].[date].&[2016-02-28t00:00:00] }     on rows [cube]; 

note

this should return all because hierarchy [date].[date] has 2 levels ... leaf level dates single level above all:

member [measures].[test] ( (ancestor      (   [date].[date].currentmember,          1 )     ).member_caption ) 

Comments

Popular posts from this blog

Load Balancing in Bluemix using custom domain and DNS SRV records -

oracle - pls-00402 alias required in select list of cursor to avoid duplicate column names -

python - Consider setting $PYTHONHOME to <prefix>[:<exec_prefix>] error -