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

Be one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now

Reply
DaxBoi
New Member

Conditional SUM

I have a dataset that looks like the following. 

For each ID there is an Attribute which has a score. There is also a target 0-4 with a weighting.

 

I'm looking to create a visual with a differential view of the weighted target score and actual score.

 

My plan is to have columns to calculate these values, however I'm struggling to formulate the DAX for the columns after the ~ symbol. 

I've tried Calculate/SUMX/Filters but can't get these to work as expected. Any help is much appreciated

 

IDAttributeScoreTargetWeighting~Sum(Target*Weight)Diff
1A1400.2~2.6+1.4
1A1410.2~2.6+1.4
1A1420~2.6+1.4
1A1430~2.6+1.4
1A1440.6~2.6+1.4
1A2.........~......
5 REPLIES 5
v-rzhou-msft
Community Support
Community Support

Hi @DaxBoi 

Could you tell me if your problem has been solved? If it is, kindly Accept it as the solution. More people will benefit from it. Or you are still confused about it, please provide me with more details about your data model and your problem or share me with your pbix file from your Onedrive for Business.

 

Best Regards,

Rico Zhou

Greg_Deckler
Super User
Super User

@DaxBoi  - You said:

"For clarity, I'm looking to sum based on a number of attributes - such as ID, and Attribute. And then do a second calculation (finding the differential) based on the same attributes"

 

PBIX is attached under sig, Table (4)

 

So, 2 columns:

Sum Target Weight = 
    VAR __Table = 
        ADDCOLUMNS(
            FILTER('Table (4)',[ID]=EARLIER([ID]) && [Attribute]=EARLIER([Attribute])),
            "Product",[Target]*[Weighting]
        )
RETURN
    SUMX(__Table,[Product])


Diff = 
    VAR __Table = 
        ADDCOLUMNS(
            FILTER('Table (4)',[ID]=EARLIER([ID]) && [Attribute]=EARLIER([Attribute])),
            "Product",[Score]*[Weighting]
        )
RETURN
    SUMX(__Table,[Product]) - [Column]

 



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...
amitchandak
Super User
Super User

@DaxBoi , As measures

 

new score = sumx(All(Table),[Target]*[Weighting])

or
new score = sumx(Allselected(Table),[Target]*[Weighting])
or
new score = calculate(sumx(Table,[Target]*[Weighting]),All(Table))

or

new score = calculate(sumx(Table,[Target]*[Weighting]),Allselected(Table))

diff = Sum(Table[Score]) -[new score]

 

As new column

new score = sumx(Table,[Target]*[Weighting]

diff = [Score] -[new score] //Both are column here

Join us as experts from around the world come together to shape the future of data and AI!
At the Microsoft Analytics Community Conference, global leaders and influential voices are stepping up to share their knowledge and help you master the latest in Microsoft Fabric, Copilot, and Purview.
️ November 12th-14th, 2024
 Online Event
Register Here

I think I wasn't clear in my question

 

The aim is to have a conditional sum that looks like this. The sum would be over the 5 total rows for


ID = 1 Attribute = A1

 

and then another sum over the rows for

 

ID = 1 Attribute = A2

 

and so on.

 

IDAttributeScoreTargetSum(T*W)Diff
1A14(0-4)2.6+1.4
+4rows asabove   
1A23(0-4)3.5-0.5
+4rows    
1A34(0-4)1+3.0
DaxBoi
New Member

For clarity, I'm looking to sum based on a number of attributes - such as ID, and Attribute. And then do a second calculation (finding the differential) based on the same attributes 

Helpful resources

Announcements
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!

Dec Fabric Community Survey

We want your feedback!

Your insights matter. That’s why we created a quick survey to learn about your experience finding answers to technical questions.

ArunFabCon

Microsoft Fabric Community Conference 2025

Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.

December 2024

A Year in Review - December 2024

Find out what content was popular in the Fabric community during 2024.