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

Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes! Register now.

Reply
digitalPlay
Frequent Visitor

How to get the next date in a filtered result

Hi All,

 

I would like to get the End Date of the first ID then subtract it from the Start Date of the next ID to get the duration between them.
The tricky part for me is that this table/visual is a result based on a filter. 
Thanks in advance! 😊

digitalPlay_0-1696839803292.png

 

1 ACCEPTED SOLUTION
Anonymous
Not applicable

Hi @digitalPlay ,

Please have a try. Create a measure.

Duration =
VAR CurrentRow =
    MAX ( 'Table'[ID] )
VAR PreviousRow =
    CALCULATE (
        MAX ( 'Table'[ID] ),
        FILTER ( ALL ( 'Table' ), 'Table'[ID] < CurrentRow )
    )
VAR StartDate =
    CALCULATE (
        MAX ( 'Table'[start date] ),
        FILTER ( ALL ( 'Table' ), 'Table'[ID] = CurrentRow )
    )
VAR EndDate =
    CALCULATE (
        MAX ( 'Table'[end date] ),
        FILTER ( ALL ( 'Table' ), 'Table'[ID] = PreviousRow )
    )
RETURN
    DATEDIFF ( EndDate, StartDate, DAY )

 

How to Get Your Question Answered Quickly 

 

If it does not help, please provide more details with your desired output and pbix file without privacy information (or some sample data) .

 

Best Regards
Community Support Team _ Rongtie

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

 

 

 

 

View solution in original post

1 REPLY 1
Anonymous
Not applicable

Hi @digitalPlay ,

Please have a try. Create a measure.

Duration =
VAR CurrentRow =
    MAX ( 'Table'[ID] )
VAR PreviousRow =
    CALCULATE (
        MAX ( 'Table'[ID] ),
        FILTER ( ALL ( 'Table' ), 'Table'[ID] < CurrentRow )
    )
VAR StartDate =
    CALCULATE (
        MAX ( 'Table'[start date] ),
        FILTER ( ALL ( 'Table' ), 'Table'[ID] = CurrentRow )
    )
VAR EndDate =
    CALCULATE (
        MAX ( 'Table'[end date] ),
        FILTER ( ALL ( 'Table' ), 'Table'[ID] = PreviousRow )
    )
RETURN
    DATEDIFF ( EndDate, StartDate, DAY )

 

How to Get Your Question Answered Quickly 

 

If it does not help, please provide more details with your desired output and pbix file without privacy information (or some sample data) .

 

Best Regards
Community Support Team _ Rongtie

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

 

 

 

 

Helpful resources

Announcements
September Power BI Update Carousel

Power BI Monthly Update - September 2025

Check out the September 2025 Power BI update to learn about new features.

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.

Top Solution Authors
Top Kudoed Authors