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

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.

Reply
mimi
Advocate I
Advocate I

max as a filter

Hi

 

I am trying to calculate sales based on the maximum invoice period, in case someone chooses multiple periods. here is my formula and it is not working. Any help will be appreciated.

 

Sales = CALCULATE(sum(Query1[SalesValue]);max(Query1[InvoicePeriod]))
 
2 ACCEPTED SOLUTIONS
Anonymous
Not applicable

Without going into whether there are any other issues with this approach, to get around the problem you have raised you'd just need to put it into a variable:

 

Sales = var filterDate = max(Query1[InvoicePeriod])
RETURN
CALCULATE(
     sum(Query1[SalesValue]);
     Query1[InvoicePeriod] = filterDate
)

You'll also need to specify what the filter condition is.  I've assumed you want records based on that date.  However you could use <= if you wanted to get all records on or before.

View solution in original post

Anonymous
Not applicable

I'd suggest creating a date table and having the slicer be based on that date table.  Then, for variable filterdate, do the max on the DateTime instead.

View solution in original post

4 REPLIES 4
Anonymous
Not applicable

Without going into whether there are any other issues with this approach, to get around the problem you have raised you'd just need to put it into a variable:

 

Sales = var filterDate = max(Query1[InvoicePeriod])
RETURN
CALCULATE(
     sum(Query1[SalesValue]);
     Query1[InvoicePeriod] = filterDate
)

You'll also need to specify what the filter condition is.  I've assumed you want records based on that date.  However you could use <= if you wanted to get all records on or before.

Hi Ross

 

Thank for replying.

However, I am noticing that if the FilterDate does not have values for that month, the value that is being produced is for other months.

 

For example, suppose the user selects Jan and Feb (represented as number 201801 and 201802). if Feb has no sales values, the result returned is for Jan. I do not want that. I prefer that the value that comes through = 0 or blank

Anonymous
Not applicable

I'd suggest creating a date table and having the slicer be based on that date table.  Then, for variable filterdate, do the max on the DateTime instead.

Yes it worked thank you

Helpful resources

Announcements
Microsoft Fabric Learn Together

Microsoft Fabric Learn Together

Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City

PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

April Fabric Community Update

Fabric Community Update - April 2024

Find out what's new and trending in the Fabric Community.