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

Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes! 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
Community Champion
Community Champion

@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!:
DAX For Humans

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
Community Champion
Community Champion

@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!:
DAX For Humans

DAX is easy, CALCULATE makes DAX hard...

Helpful resources

Announcements
FabCon Global Hackathon Carousel

FabCon Global Hackathon

Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes!

September Power BI Update Carousel

Power BI Monthly Update - September 2025

Check out the September 2025 Power BI update to learn about new features.

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.

Top Solution Authors
Top Kudoed Authors