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
I have a claims history table with multiple rows for each claim number. Each row provides the claim number, the status of the claim, and a date when that status occurred. I'm trying to count the number of claims that are currently open/reopened based on a date slicer the user can control. A simple view of my data:
Claim Number | Status | Date | Rank |
123 | Open | 7/26/2016 | 1 |
123 | Close | 11/7/2016 | 2 |
123 | Reopened | 1/23/2017 | 3 |
123 | Closed | 2/21/2017 | 4 |
456 | Open | 1/25/2017 | 1 |
456 | Closed | 3/1/2017 | 2 |
I added a rank column thinking it might help me select the max rank as of a given date, which could then be linked to the status but I haven't been able to figure out how to do that.
What I am trying to get at :
given the data in the above table if a user selected via a slicer (DimDate[Date] serves as the field for the slicer) the following dates, I would return the following number of claims.
On Date | # of Open Claims |
8/1/2016 | 1 |
12/1/2016 | 0 |
1/25/2017 | 2 |
2/27/2017 | 1 |
Any help on creating the measure for this would be greatly appreciated.
Solved! Go to Solution.
Here's my thought on how to tackle this. I created your table in Excel and imported it into PBI, then did the following:
DateTable = Calendar(Minx(table1,Table1[Date]),Now())
AllTimeOpened = CALCULATE( COUNTROWS(Table1), FILTER(Table1, DateTable[Date] >= Table1[Date] && Table1[Status] = "Open") )
AllTimeReopened = CALCULATE( COUNTROWS(Table1), FILTER(Table1, DateTable[Date] >= Table1[Date] && Table1[Status] = "Reopened") )
AllTimeClosed = CALCULATE( COUNTROWS(Table1), FILTER(Table1, DateTable[Date] >= Table1[Date] && Table1[Status] = "Closed") )
Open Cases = CALCULATE( VALUES(DateTable[AllTimeOpened]) + VALUES(DateTable[AllTimeReopened]) - VALUES(DateTable[AllTimeClosed] ) )
The result of all this is that I have a count in my date table of how many actively open cases there are on any given day. I can chart this out, but if I try to make a card/slicer it gives me inaccurate data because it sums up my column. Instead I probably want to make it a calculated measure instead. The measure will only be meaningful if a date slicer is used, so I wrote it as such:
Open Measure = IFERROR( CALCULATE( VALUES(DateTable[AllTimeOpened]) + VALUES(DateTable[AllTimeReopened]) - VALUES(DateTable[AllTimeClosed] ) ), "Use Slicer")
Might be a better way to do that.
Anyway, here are the visual results:
Is this on the right path of what you're looking for?
Dan
Here's my thought on how to tackle this. I created your table in Excel and imported it into PBI, then did the following:
DateTable = Calendar(Minx(table1,Table1[Date]),Now())
AllTimeOpened = CALCULATE( COUNTROWS(Table1), FILTER(Table1, DateTable[Date] >= Table1[Date] && Table1[Status] = "Open") )
AllTimeReopened = CALCULATE( COUNTROWS(Table1), FILTER(Table1, DateTable[Date] >= Table1[Date] && Table1[Status] = "Reopened") )
AllTimeClosed = CALCULATE( COUNTROWS(Table1), FILTER(Table1, DateTable[Date] >= Table1[Date] && Table1[Status] = "Closed") )
Open Cases = CALCULATE( VALUES(DateTable[AllTimeOpened]) + VALUES(DateTable[AllTimeReopened]) - VALUES(DateTable[AllTimeClosed] ) )
The result of all this is that I have a count in my date table of how many actively open cases there are on any given day. I can chart this out, but if I try to make a card/slicer it gives me inaccurate data because it sums up my column. Instead I probably want to make it a calculated measure instead. The measure will only be meaningful if a date slicer is used, so I wrote it as such:
Open Measure = IFERROR( CALCULATE( VALUES(DateTable[AllTimeOpened]) + VALUES(DateTable[AllTimeReopened]) - VALUES(DateTable[AllTimeClosed] ) ), "Use Slicer")
Might be a better way to do that.
Anyway, here are the visual results:
Is this on the right path of what you're looking for?
Dan
@danrmcallister I'm running into an error with trying to create the measure - it's telling me that the syntax is incorrect. Any ideas on why I might be getting that error?
My Measure in the Date Table:
Open Measure = CALCULATE(
VALUES(Date[AllTimeOpened])+
VALUES('Date'[AllTimeReopened]) -
VALUES('Date'[AllTimeClosed]))
ERROR:
The syntax for '[AllTimeOpened]' is incorrect. (DAX(CALCULATE( VALUES(Date[AllTimeOpened])+ VALUES('Date'[AllTimeReopened]) - VALUES('Date'[AllTimeClosed])))).
The "AllTimeOpened", "AllTimeReopened", and "AllTimeClosed" fields you see below were calculated columns I created against my date table. Did you complete that step first?
@danrmcallister I created all three of the calculated columns, and I just realized the VERY basic obvious reason why I was getting a syntax error. I didn't have Date in quotes for the first VALUES in my measure. I have now fixed that and my error is gone. I can now officially test the code. Thank you again for your time!
@danrmcallister The good news - I was able to get this to work, and the logic works for filtering by date. The problem I'm realizing is that I can't have the counts in the Date table because if the user wants to filter the data by anything else (additional fields that I didn't show but are common for the user to bring into the Data table like cause of loss) they won't be able to filter by any additional fields. Thank you for all of your time.
Did you try creating a relationship between your date table and your fact table based on the date? It should work!
@danrmcallister I think I must be missing something simple. I have a relationship between my Date table and Fact table (link is on the Date). I have two filters on my sheet, the first is a 'Date'[Date] filter. The second is a FactTable[loss cause] filter. My claims count changes if the Date filter changes (and it changes the options available on my loss cause filter). However, nothing happens to the open claims count if I select a single specific loss cause. With the sample you created, if you added a column in Table1 titled Loss Cause and give claim 123 a cause of "trip" and claim 456 a cause of "accident", are you able to add a second filter for Loss Cause and have it work?
@danrmcallister I got it to work the way I need based on your suggestions - thank you so much for your help! I created three measures in my fact table that gave me a total of open, reopened, and closed claims (code provided for one of those measures). Then I created a measure based on those three measures: adding total open to reopened and subtracts claims, which interacts with both a date and loss cause filter.
Count Closes =
VAR EndingDate =
MAX ( 'Date'[Date] )
RETURN
( CALCULATE (COUNTROWS (FactTable), 'Date'[Date] <= EndingDate, FactTable[Status] = "Closed"))
@danrmcallister Thank you for the response! Appears this should get me what I need. Putting it in now to test. Will let you know final verdict.
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.
Learn from experts, get hands-on experience, and win awesome prizes.
User | Count |
---|---|
110 | |
78 | |
76 | |
41 | |
37 |
User | Count |
---|---|
157 | |
113 | |
64 | |
60 | |
55 |