Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Get certified in Microsoft Fabric—for free! For a limited time, get a free DP-600 exam voucher to use by the end of 2024. Register now

Reply
EnderWiggin
Helper I
Helper I

Create calculated table from two tables

Hi All,

I would like to create a measure which shows top3 users by name based on their summarized activity values from 'User table' and 'User Activity table'. The filter connection between the tables is 'User table' 1 - many 'User activity table'

top3useracitivity.png

The measure result should be a calcualted tabe with two columns: User table [Name], and sum of [Quantity] from User Activity table.

 I tried to do it with CALCULATEDTABLE, TOPN and ADDCOLUMN functions, but I can not figure out the correct measure definition. Could you help me to solve this? Thank you very much!

1 ACCEPTED SOLUTION
Greg_Deckler
Super User
Super User

@EnderWiggin Try below. PBIX is attached below signature.

Username Sum Quantity Top 3 = 
    VAR __BaseTable = 
        SUMMARIZE(
            'User Activity Table',
            [UserId],
            "Sum Quantity", SUM('User Activity Table'[Quantity])
        )
    VAR __Table = 
        ADDCOLUMNS(
            __BaseTable,
            "Username", MAXX(FILTER('User Table', [Id] = [UserId]),[Name]),
            "Rank", RANKX(__BaseTable, [Sum Quantity],,DESC)
        )
    VAR __Result =
        SELECTCOLUMNS(
            FILTER(__Table, [Rank] <= 3),
            "Username", [Username],
            "Sum Quantity", [Sum Quantity]
        )
RETURN
    __Result

 



Follow on LinkedIn
@ me in replies or I'll lose your thread!!!
Instead of a Kudo, please vote for this idea
Become an expert!: Enterprise DNA
External Tools: MSHGQM
YouTube Channel!: Microsoft Hates Greg
Latest book!:
Power BI Cookbook Third Edition (Color)

DAX is easy, CALCULATE makes DAX hard...

View solution in original post

2 REPLIES 2
EnderWiggin
Helper I
Helper I

@Greg_Deckler thank you very much for your detailed and clear solution, this is what I wanted.  

Greg_Deckler
Super User
Super User

@EnderWiggin Try below. PBIX is attached below signature.

Username Sum Quantity Top 3 = 
    VAR __BaseTable = 
        SUMMARIZE(
            'User Activity Table',
            [UserId],
            "Sum Quantity", SUM('User Activity Table'[Quantity])
        )
    VAR __Table = 
        ADDCOLUMNS(
            __BaseTable,
            "Username", MAXX(FILTER('User Table', [Id] = [UserId]),[Name]),
            "Rank", RANKX(__BaseTable, [Sum Quantity],,DESC)
        )
    VAR __Result =
        SELECTCOLUMNS(
            FILTER(__Table, [Rank] <= 3),
            "Username", [Username],
            "Sum Quantity", [Sum Quantity]
        )
RETURN
    __Result

 



Follow on LinkedIn
@ me in replies or I'll lose your thread!!!
Instead of a Kudo, please vote for this idea
Become an expert!: Enterprise DNA
External Tools: MSHGQM
YouTube Channel!: Microsoft Hates Greg
Latest book!:
Power BI Cookbook Third Edition (Color)

DAX is easy, CALCULATE makes DAX hard...

Helpful resources

Announcements
November Carousel

Fabric Community Update - November 2024

Find out what's new and trending in the Fabric Community.

Live Sessions with Fabric DB

Be one of the first to start using Fabric Databases

Starting December 3, join live sessions with database experts and the Fabric product team to learn just how easy it is to get started.

Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early Bird pricing ends December 9th.

Nov PBI Update Carousel

Power BI Monthly Update - November 2024

Check out the November 2024 Power BI update to learn about new features.