The ultimate Microsoft Fabric, Power BI, Azure AI, and SQL learning event: Join us in Stockholm, September 24-27, 2024.
Save €200 with code MSCUST on top of early bird pricing!
Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started
Hi guys,
I have created this measure (Measure1) that actually obtain the result I want to discover and gives not many problem in limited filter context like table with few rows.
Measure1=
CALCULATE(
From the Measure 0 I am creating a context where from the price list I am creating a table with only the values "old price" area greater than zero and then creating and then the if statement.
The measure 1 is using the measure 0 only where is retrieving the fiscal period from the price list with related.
Can someone help me maybe with a best practice to fix the formula?
Really thank you in advance for your help,
Regards,
ES
Solved! Go to Solution.
Hi,
Now that the issue is total not showing I would recommend checking this article by SQLBI:
Obtaining accurate totals in DAX - SQLBI
In short try utilizing methods such as SUMX to get the total value.
Proud to be a Super User!
Hi,
The issue is likely caused by your use of RELATED and additionally the use of complex logic within IF statement. RELATED function often suffers from performance issues and it should be avoided when possible. In your dax you use related to filter upcoming fiscal periods for calculation: FILTER( 'Accounting', 'Accounting'[Fiscal Period] >= RELATED( 'Price Lists'[Fiscal Period] )
The first question to ask here is if you can achieve the same calculation without using RELATED e.g. using MAX:
Measure1=
CALCULATE(
Measure1=
var _period = MAX( 'Price Lists'[Fiscal Period] )
CALCULATE(
Proud to be a Super User!
Hi @ValtteriN,
Thank you for your quick response.
Unfortunately, I can not reach the same result with the MAX measure (in this case it would retrieve the higher fiscal period in the price list fact table) where instead I need the exact fiscal period for start the calculations.
For instance if in the price list table there is the customer "BigCompany" with item "RedItem" with fiscal period 2023004, I need to start my calculation from FY 2023004 ( >= related (price list[fiscalperiod]) )
I see, maybe you could calculate the desired fiscal year using CALCULATE()? It is hard to provide example fitting your use case without seeign the data, but the basic idea is as follows:
Instead of using RELATED you would use the same filter context in variable
var _FY =
CALCULATE(MAX( 'accounting period'[Fiscal Period]), ALL(accounting period[Fiscal Period]), 'accounting period'[Fiscal Period] =MAX( 'Price Lists'[Fiscal Period]))
return
CALCULATE(
This dax might or might not work depending on your data, but the basic idea should function with some changes.
Proud to be a Super User!
Hi Again @ValtteriN ,
The formula looks working and in a fast way, but it show a mistake: it computes the calculation for the last value from 'Price List' "2023004" while 'accounting' fact table has arrived only at '2023003'.
I have tried many changes like inverting this filter 'accounting period'[Fiscal Period] =MAX( 'Price Lists'[Fiscal Period]) in 'Price List'[Fiscal Period] =MAX( 'accounting'[Fiscal Period]) but no result.
Instead I found this version working (but not showing result in total)
Hi,
Now that the issue is total not showing I would recommend checking this article by SQLBI:
Obtaining accurate totals in DAX - SQLBI
In short try utilizing methods such as SUMX to get the total value.
Proud to be a Super User!
Join the community in Stockholm for expert Microsoft Fabric learning including a very exciting keynote from Arun Ulag, Corporate Vice President, Azure Data.
Check out the August 2024 Power BI update to learn about new features.
User | Count |
---|---|
22 | |
20 | |
19 | |
18 | |
13 |
User | Count |
---|---|
41 | |
39 | |
24 | |
22 | |
20 |