Business Intelligence Blogs

View blogs by industry experts on topics such as SSAS, SSIS, SSRS, Power BI, Performance Tuning, Azure, Big Data and much more! You can also sign up to post your own business intelligence blog.

MDX Utility Belt of Calculations Part 1

  • 1 December 2009
  • Author: DevinKnight
  • Number of views: 9090

Developing MDX calculations is one of the most confusing and time consuming pieces of building an Analysis Services cube.  That is why I have accumulated what I like to call a Utility Belt of calculation that I can pull out at any moment to solve a problem.  I consider this a Utility Belt because on just about every Analysis Services project that I have worked on these calculations have come in handy and I hope they will be helpful for you.

When building calculations you may find the templates that are available in Business Intelligence Development Studio (BIDS) as a helpful starting point.  Unfortunately, I have found even using these templates can make calculations more confusing than they really need to be.

In this blog series I will give you the business problem, solution, and then calculation that satisfies the business problem. 


You need to return sales for one year prior (Ex. one year ago, four quarters ago, twelve months ago).


Use the ParrallelPeriod time series function to look back a set number of values back in a date hierarchy and return the sales at that point.


Looking back one year at the Year level

(ParallelPeriod([Date].[Date Hierarchy].[Year],
[Date].[Date Hierarchy].CurrentMember),
[Measures].[Sales Amount])


Looking back four quarters at the Quarter level

(ParallelPeriod([Invoice Date].[Date Hierarchy].[Quarter],
[Invoice Date].[Date Hierarchy].CurrentMember),
[Measures].[Sales Amount])


Looking back twelve months at the Month level

(ParallelPeriod([Invoice Date].[Date Hierarchy].[Month],
[Invoice Date].[Date Hierarchy].CurrentMember),
[Measures].[Sales Amount])

Rate this article:


Other posts by DevinKnight

Please login or register to post comments.