Register now to learn Fabric in free live sessions led by the best Microsoft experts. From Apr 16 to May 9, in English and Spanish.
Hi,
I am calculating earned premium up till a specific date using the variable "LatestReportingDate".
However, when using this variable, the filter context "YOA <= 2020" is kept.
Earned =
VAR LatestReportingDate =
CALCULATE(MAX(TABLE[ReportingPeriodStartDate]),
FILTER(TABLE, TABLE[YOA] <= 2020))
RETURN CALCULATE(SUM(TABLE[EarnedPremium]),
FILTER(TABLE, TABLE[ReportingPeriodStartDate] = LatestReportingDate)
)
When visualizing
Class | 1 | 2 |
YOA | Earned | Earned |
2019 | xxx | xxx |
2020 | xxx | xxx |
2021 | BLANK | BLANK |
2022 | BLANK | BLANK |
It seems the filter context from LatestReportingPeriod spills over such that earned is not calculated for 2021 and 2022 YOA.
I have tried using ALL, ALLEXCEPT to no avail. This also removes connections in the model, which I do not want.
Solved! Go to Solution.
Hi @MrMichael
The LatestReportingDate will return the last available date in in current filter context only if the year is 2020 or less. In the case of the year 2021 it will return blank. In this case the measure will also return blank as there is no blank date in your table.
You can FILTER ( ALL ( Table ), ..... in both measures but the best way to achieve what you need is the have a date table.
Hi @MrMichael
The LatestReportingDate will return the last available date in in current filter context only if the year is 2020 or less. In the case of the year 2021 it will return blank. In this case the measure will also return blank as there is no blank date in your table.
You can FILTER ( ALL ( Table ), ..... in both measures but the best way to achieve what you need is the have a date table.
Thank you.
However, I find that using ALL on both measures, removes connections in my model which makes earned premium the same for all years.
@MrMichael
This is why I advised you to use a date table. This will give you the freedom to filter without the need for sophisticated dax code.
@MrMichael try this:
Earned =
VAR LatestReportingDate =
CALCULATE (
MAX ( TABLE[ReportingPeriodStartDate] ),
TABLE[YOA] <= 2020
)
RETURN
CALCULATE (
SUM ( TABLE[EarnedPremium] ),
TABLE[ReportingPeriodStartDate] = LatestReportingDate
)
Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City
Check out the April 2024 Power BI update to learn about new features.
User | Count |
---|---|
47 | |
26 | |
19 | |
14 | |
10 |
User | Count |
---|---|
58 | |
50 | |
44 | |
19 | |
19 |