Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Newsletter Hub
Free Learning
Arrow right icon
timer SALE ENDS IN
0 Days
:
00 Hours
:
00 Minutes
:
00 Seconds
Arrow up icon
GO TO TOP
MDX with SSAS 2012 Cookbook

You're reading from   MDX with SSAS 2012 Cookbook In this book you'll find 90 clearly written recipes to help developers advance their skills with the demanding but powerful language MDX and SQL Server Analysis Services. All leading to greatly improved business intelligence solutions.

Arrow left icon
Product type Paperback
Published in Aug 2013
Publisher Packt
ISBN-13 9781849689601
Length 420 pages
Edition 2nd Edition
Arrow right icon
Toc

Table of Contents (16) Chapters Close

MDX with SSAS 2012 Cookbook
Credits
About the Authors
About the Reviewers
www.PacktPub.com
Preface
1. Elementary MDX Techniques FREE CHAPTER 2. Working with Sets 3. Working with Time 4. Concise Reporting 5. Navigation 6. Business Analytics 7. When MDX is Not Enough 8. Advanced MDX Topics 9. On the Edge Index

Basic sorting and ranking


Sorting and ranking are very common requirements in most business analysis, and MDX provides several functions for this purpose. They are:

  • TopCount and BottomCount

  • TopPercent and BottomPercent

  • TopSum and BottomSum

  • Order

  • Hierarchize

  • Rank

All of these functions operate on sets of tuples, not just on one-dimensional sets of members. They all, in some way, involve a numeric expression, which is used to evaluate the sorting and the ranking.

Getting ready

We will start with the classic Top 5 (or Top-n) example using the TopCount() function. We will then examine how the result is already pre-sorted, followed by using the Order() function to sort the result explicitly. Finally, we will see how we can add a ranking number by using the Rank() function.

Here is the classic Top 5 example using the TopCount() function

TopCount (
        [Product].[Subcategory].children,
        5,
        [Measures].[Internet Sales Amount] 
  )

It operates on a tuple ([Product].[Subcategory].children, [Measures].[Internet Sales Amount]).

The result is the five [Subcategory] that has the highest [Internet Sales Amount].

The five subcategory members will be returned in order from the largest [Internet Sales Amount] to the smallest.

How to do it…

In SSMS, let us write the following query in a new Query Editor, against the Adventure Works DW 2012 database. Follow these steps to first get the top-n members:

  1. We simply place the earlier TopCount() expression on the rows axis.

  2. On the columns axis, we are showing the actually sales amount for each product subcategory.

  3. In the slicer, we use a tuple to slice the result for the year 2008 and the Southwest only.

  4. The final query should look like the following query:

    SELECT
        [Measures].[Internet Sales Amount] on 0,
        TopCount (
            [Product].[Subcategory].children,
            5,
            [Measures].[Internet Sales Amount] 
        ) ON 1
    FROM
       [Adventure Works]
    WHERE
       ( [Date].[Calendar].[Calendar Quarter].&[2008]&[1],
         [Sales Territory].[Sales Territory Region].[Southwest]
       )
  5. Run the query. The following screenshot shows the Top-n result:

  6. Notice that the returned members are in order from the largest numeric measure to the smallest.

Next, in SSMS, follow these steps to explicitly sort the result:

  1. This time, we will put the TopCount() expression in the WITH clause, creating it as a Named Set. We will name it [Top 5 Subcategory].

  2. On the rows axis, we will use the Order() function, which takes two parameters: which members we want to return and what value we want to evaluate on for sorting. The named set [Top 5 Subcategory] is what we want to return, so we will pass it to the Order() function as the first parameter. The .MemberValue function gives us the product subcategory name, so we will pass it to the Order() function as the second parameter. Here is the Order() function expression we would use:

    ORDER (
             [Top 5 Subcategory],
             [Product].[Subcategory].MEMBERVALUE
        )
  3. Here is the final query for sorting the result:

    -- Order members with MemberValue
    WITH
    SET [Top 5 Subcategory] as
       TopCount (
           [Product].[Subcategory].CHILDREN,
           5,
           [Measures].[Internet Sales Amount]
       )
    
    SELECT
        [Measures].[Internet Sales Amount] on 0,
        ORDER (
            [Top 5 Subcategory],
            [Product].[Subcategory].MEMBERVALUE
        ) ON 1
    FROM
        [Adventure Works]
    WHERE
        ( [Date].[Calendar].[Calendar Quarter].&[2008]&[1],
          [Sales Territory].[Sales Territory 
            Region].[Southwest] )
  4. Executing the preceding query, we get the sorted result as the screenshot shows:

Finally, in SSMS follow these steps to add ranking numbers to the Top-n result:

  1. We will create a new calculated measure [Subcategory Rank] using the Rank() function, which is simply putting a one-based ordinal position of each tuple in the set [Top 5 Subcategory]. Since the set is already ordered, the ordinal position of the tuple will give us the correct ranking. Here is the expression for the Rank() function:

       RANK (
           [Product].[Subcategory].CurrentMember,
           [Top 5 Subcategory]
       )
  2. The following query is the final query. It is built on top of the first query in this recipe. We've added the earlier Rank() function and created a calculated measure [Measures].[Subcategory Rank], which is placed on the columns axis along with the Internet Sales Amount.

    WITH
    SET [Top 5 Subcategory] AS
       TopCount (
           [Product].[Subcategory].children,
           5,
           [Measures].[Internet Sales Amount] 
       )
    MEMBER [Measures].[Subcategory Rank] AS
        RANK ( 
           [Product].[Subcategory].CurrentMember, 
           [Top 5 Subcategory]
       )
    
    SELECT
        { [Measures].[Internet Sales Amount],
          [Measures].[Subcategory Rank]
        } ON 0,
        [Top 5 Subcategory] ON 1	
    FROM
        [Adventure Works]
    WHERE
        ( [Date].[Calendar].[Calendar Quarter].&[2008]&[1],
          [Sales Territory].[Sales Territory Region].[Southwest] )
  3. Run the preceding query. The ranking result is shown in the following screenshot:

How it works…

Sorting functions, such as TopCount(), TopPercent(), and TopSum() operate on sets of tuples. These tuples are evaluated on a numeric expression and returned pre-sorted in the order of a numeric expression.

Using the Order() function, we can sort members from dimensions explicitly using the .MemberValue function.

When a numeric expression is not specified, the Rank() function can simply be used to display the one-based ordinal position of tuples in a set.

There's more…

Like the other MDX sorting functions, the Rank() function, however, can also operate on a numeric expression. If a numeric expression is specified, the Rank() function assigns the same rank to tuples with duplicate values in the set.

It is also important to understand that the Rank() function does not order the set. Because of this fact, we tend to do the ordering and ranking at the same time. However, in the last query of this recipe, we actually used the Order() function to first order the set of members of the subcategory. This way, the sorting is done only once and then followed by a linear scan, before being presented in sorted order.

As a good practice, we recommend using the Order() function to first order the set and then ranking the tuples that are already sorted.

You have been reading a chapter from
MDX with SSAS 2012 Cookbook - Second Edition
Published in: Aug 2013
Publisher: Packt
ISBN-13: 9781849689601
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime