CREATING THE DIMENSION
In order to achieve this I have created a dummy dimension, similar to a ‘time utility dimension’ (also known as a ‘date tool’ dimension or a ‘shell’ dimension. I had advice from Chris Webb regarding this, he also referred me the book ‘Expert Cube Development with SQL Server Analysis Services 2008’) and then add a calculated member to it with two values.
We do not need to create a table in our Data warehouse for this purpose; we can create a view some thing like this
CREATE VIEW RevenueAsPositive AS
SELECT 0 AS ID, 'Convert Revenue to Positive' AS Description
UNION ALL
SELECT 1 AS ID, 'Stay Revenue as Negative' AS Description
Now we need to add this view inside our DSV and create a dimension based on this view
Alternatively we can create some thing like this inside our DSV
data:image/s3,"s3://crabby-images/e570f/e570fb632831afcc16f293a7da0d2050050ce4bd" alt=""
So this dimension has two values
1. Convert Revenue to Positive --> 0
2. Stay Revenue as Negative --> 1
This dimension has no relationship with fact table as shown in the figure
data:image/s3,"s3://crabby-images/24589/245894ae3e71b4f9a488f6587dff3c35a4985197" alt=""
CONFIGURING THE DIMENSION
After creating this dimension now you need to set the properties of the attribute hierarchy
• Set “DefaultMember” to ‘Stay Revenue as Negative’, as below:
data:image/s3,"s3://crabby-images/014a7/014a7e00c587941ee85db30db537f9e9daff13b1" alt=""
•Set the “IsAggregatable” property to “False”, so there’s no All Member on the attribute hierarchy, as below:
data:image/s3,"s3://crabby-images/df20f/df20f53a827944ffb3a50d7717147d028378173e" alt=""
In the following picture you can see all the revenue figures are negative, which is the default behavior we have defined inside the Analyses Services Cube
data:image/s3,"s3://crabby-images/54941/54941818d21004df4507f2a48ddcfd3f5a268211" alt=""
If now the user would like to convert the revenue figures to display as positive, they need to set the report filter to Convert Revenue to Positive as shown in the following figure:
data:image/s3,"s3://crabby-images/5e2c2/5e2c2367864b65047346f088e3659d1923107381" alt=""
In order to achieve this functionality you need to use a scoped assignment using MDX that’s something like this:
When the user chooses “Convert Revenue to Positive” than I multiplied all actual measure values by -1, using this MDX:
SCOPE([Convert Revenue To Positive].[Convert Revenue To Positive].&[0],descendants([Dimension POST CODE].[Post Code Structure].[PC Level 2].&[IREV],[Dimension POST CODE].[Post Code Structure].[Post Code],self_and_before),[Measures].[YTD Actuals]
);
This =(([Dimension POST CODE].[Post Code Structure].currentmember)*(-1));
END SCOPE;
SCOPE([Convert Revenue To Positive].[Convert Revenue To Positive].&[0],descendants([Dimension POST CODE].[Post Code Structure].[PC Level 2].&[EREV],[Dimension POST CODE].[Post Code Structure].[Post Code],self_and_before),[Measures].[YTD Actuals]
);
This =(([Dimension POST CODE].[Post Code Structure].currentmember)*(-1));
END SCOPE;
Notice that the “Profit and Loss” values do not change even though the Revenue values have changed to positive. This is achieved through the following SCOPE statement:
SCOPE([Convert Revenue To Positive].[Convert Revenue To Positive].&[0],[Dimension POST CODE].[Post Code Structure].[PC Level 1].&[PL],[Measures].[YTD Actuals]
);
This =(([Dimension POST CODE].[Post Code Structure].&[EEXP])+[Dimension POST CODE].[Post Code Structure].&[IEXP]-[Dimension POST CODE].[Post Code Structure].&[IREV]-[Dimension POST CODE].[Post Code Structure].&[EREV]);
END SCOPE;
Hopefully this will help you if you are trying to build some similar functionality.
Finally, I would like to acknowledge and thank Chris Webb for his suggestions and support, thank you Chris.