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

Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.

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
v-rongtiep-msft
Community Support
Community Support

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
v-rongtiep-msft
Community Support
Community Support

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
LearnSurvey

Fabric certifications survey

Certification feedback opportunity for the community.