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

Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started

Reply
MoreDataPlease
Frequent Visitor

Dynamic Column Count Based on Date Slicer Selection

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 NumberStatusDateRank
123Open7/26/20161
123Close11/7/20162
123Reopened1/23/20173
123Closed2/21/20174
456Open1/25/20171
456Closed3/1/20172

 

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/20161
12/1/20160
1/25/20172
2/27/20171

 

Any help on creating the measure for this would be greatly appreciated. 

1 ACCEPTED SOLUTION
danrmcallister
Resolver II
Resolver II

Here's my thought on how to tackle this.  I created your table in Excel and imported it into PBI, then did the following:

 

  • Created a date table
    DateTable = Calendar(Minx(table1,Table1[Date]),Now()) 
     
  • To the date table I added 3 calculated columns, purpose being to count how many claims have been opened, reopened, and closed all time as of that date:
  • 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")
    )
  • Then to the date table, I added another calculated column called "Open Cases"
  • 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:

 

PBI Open Reopen 1.jpgPBI Open Reopen 2.jpg

 

 

Is this on the right path of what you're looking for?

 

Dan

View solution in original post

9 REPLIES 9
danrmcallister
Resolver II
Resolver II

Here's my thought on how to tackle this.  I created your table in Excel and imported it into PBI, then did the following:

 

  • Created a date table
    DateTable = Calendar(Minx(table1,Table1[Date]),Now()) 
     
  • To the date table I added 3 calculated columns, purpose being to count how many claims have been opened, reopened, and closed all time as of that date:
  • 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")
    )
  • Then to the date table, I added another calculated column called "Open Cases"
  • 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:

 

PBI Open Reopen 1.jpgPBI Open Reopen 2.jpg

 

 

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?

 

PBI Open Reopen 3.jpgPBI Open Reopen 4.jpg

@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.

Helpful resources

Announcements
Europe Fabric Conference

Europe’s largest Microsoft Fabric Community Conference

Join the community in Stockholm for expert Microsoft Fabric learning including a very exciting keynote from Arun Ulag, Corporate Vice President, Azure Data.

AugPowerBI_Carousel

Power BI Monthly Update - August 2024

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

August Carousel

Fabric Community Update - August 2024

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