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

Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started

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!:
The Definitive Guide to Power Query (M)

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!:
The Definitive Guide to Power Query (M)

DAX is easy, CALCULATE makes DAX hard...

Helpful resources

Announcements
Europe Fabric Conference

Europe’s largest Microsoft Fabric Community Conference

Join the community in Stockholm for expert Microsoft Fabric learning including a very exciting keynote from Arun Ulag, Corporate Vice President, Azure Data.

Power BI Carousel June 2024

Power BI Monthly Update - June 2024

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

RTI Forums Carousel3

New forum boards available in Real-Time Intelligence.

Ask questions in Eventhouse and KQL, Eventstream, and Reflex.