Advance your Data & AI career with 50 days of live learning, dataviz contests, hands-on challenges, study groups & certifications and more!
Get registeredJoin us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM. Register now.
Hi,
I'm looking to create a DAX formula in Power BI that calculates a running total but also provides breakdowns and overall sums at different levels. Here's the scenario:
Desired Outcome:
I want to achieve the following calculations:
Current Formula:
I've tried the following formula, but if it does correctly sum by product types, it does not by account type. I do not understand why...
RunningTotalValue =
VAR _CurrentMonth = MAX(month_table[cy_month_number])
VAR _CurrentFiscalYear = MAX(net_marg_product_lines[fiscal_year])
RETURN
CALCULATE(
SUM(net_marg_product_lines[amount]),
FILTER(
ALLSELECTED(month_table),
month_table[fy_month_number] <= _CurrentMonth
),
FILTER(
ALLSELECTED(net_marg_product_lines),
net_marg_product_lines[fiscal_year] = _CurrentFiscalYear
)
)
Example with two accounts and two products for July and August:
July 2023 | July 2023 | July 2023 | August 2023 | August 2023 | August 2023 | |
Product | Income | Transport | Margin (Total) | Income | Transport | Margin (Total) |
Gr-1 | 350000 | -7000 | 34300 | 390000 (July + August) | -1400 | 388600 |
Gr-2 | 7800 | -900 | 6900 | 10000 | -1500 | 8500 |
TOTAL | 357800 | -7900 | 349900 | 400000 | -2900 | 397100 |
@marie_joy Try with:
RunningTotal =
CALCULATE(
SUM(net_marg_product_lines[amount]),
FILTER(
ALLSELECTED(month_table),
month_table[cy_month_number] <= MAX(month_table[cy_month_number])
),
FILTER(
ALLSELECTED(net_marg_product_lines),
net_marg_product_lines[fiscal_year] = MAX(net_marg_product_lines[fiscal_year])
)
)
LastAvailableValue =
VAR CurrentMonth = MAX(month_table[cy_month_number])
VAR FiscalYear = MAX(net_marg_product_lines[fiscal_year])
VAR LastMonthWithValue =
CALCULATE(
MAX(month_table[cy_month_number]),
FILTER(
ALL(net_marg_product_lines),
net_marg_product_lines[fiscal_year] = FiscalYear &&
net_marg_product_lines[amount] <> BLANK()
)
)
VAR LastValue =
CALCULATE(
SUM(net_marg_product_lines[amount]),
FILTER(
ALL(month_table),
month_table[cy_month_number] = LastMonthWithValue
),
FILTER(
ALL(net_marg_product_lines),
net_marg_product_lines[fiscal_year] = FiscalYear
)
)
RETURN
IF(
ISBLANK(SUM(net_marg_product_lines[amount])),
LastValue,
SUM(net_marg_product_lines[amount])
)
BBF
I found a solution but I do not understand it. If I remove
FILTER( ALLSELECTED(net_marg_product_lines), net_marg_product_lines[fiscal_year] = _CurrentFiscalYear
from the DAX formula, I do have correct calculations...
If anyone can explain why, I will greatly appreciate!
Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes!
Check out the October 2025 Power BI update to learn about new features.
User | Count |
---|---|
8 | |
6 | |
3 | |
3 | |
3 |
User | Count |
---|---|
11 | |
9 | |
8 | |
7 | |
6 |