Power BI is turning 10, and we’re marking the occasion with a special community challenge. Use your creativity to tell a story, uncover trends, or highlight something unexpected.
Get startedJoin us for an expert-led overview of the tools and concepts you'll need to become a Certified Power BI Data Analyst and pass exam PL-300. Register now.
I need to identify recorders that have been changed so that they can be flagged, something like below the table.
the data come from a table containing rolling 90 days record
Date | Ref | Status | Status changed |
1/02/2017 | 1 | A | 0 |
2/02/2017 | 1 | A | 0 |
3/02/2017 | 1 | B | 1 |
1/02/2017 | 2 | A | 0 |
2/02/2017 | 2 | V | 1 |
3/02/2017 | 2 | A | 1 |
Solved! Go to Solution.
Hi @Sir_night,
It's obviously there is an order of "Date" for a "Ref" in your scenario. So let's sort the data first, then add an index to keep the orders. Finally, we just need to compare "Status" between "index" and "index + 1".
1. Open "Query Editor", do "Sort Ascending" of "Ref", then do "Sort Ascending" of "Date". There will be two arrows. (blue rectangle). Please don't break the order of ordering. "Ref" first, "Date" second.
2. Add an index.
3. Add a calculated column.
Status changed = VAR NextStatus = CALCULATE ( VALUES ( Table1[Status] ), FILTER ( ALL ( 'Table1' ), 'Table1'[Ref] = EARLIER ( Table1[Ref] ) && 'Table1'[Index] = EARLIER ( Table1[Index] ) - 1 ) ) RETURN IF ( ISBLANK ( NextStatus ), 0, IF ( 'Table1'[Status] = NextStatus, 0, 1 ) )
Best Regards!
Dale
Hi David,
It would be a little complicated.
Method 1: Add a new column, tag the previous record only. (depend on [Status changed])
Status changed = VAR NextStatus = CALCULATE ( VALUES ( Table1[Status] ), FILTER ( ALL ( 'Table1' ), 'Table1'[Ref] = EARLIER ( Table1[Ref] ) && 'Table1'[Index] = EARLIER ( Table1[Index] ) - 1 ) ) RETURN IF ( ISBLANK ( NextStatus ), 0, IF ( 'Table1'[Status] = NextStatus, 0, 1 ) )
Method 2: there are four statuses here. (independant)
0 isn't changed and isn't previous
1 changed and isn't previous
2 isn't changed and previous
3 changed and previous
StatusFlag = VAR LastStatus = CALCULATE ( VALUES ( Table1[Status] ), FILTER ( ALL ( 'Table1' ), 'Table1'[Ref] = EARLIER ( Table1[Ref] ) && 'Table1'[Index] = EARLIER ( Table1[Index] ) - 1 ) ) VAR NextStatus = CALCULATE ( VALUES ( Table1[Status] ), FILTER ( ALL ( 'Table1' ), 'Table1'[Ref] = EARLIER ( Table1[Ref] ) && 'Table1'[Index] = EARLIER ( Table1[Index] ) + 1 ) ) RETURN IF ( ISBLANK ( LastStatus ) && 'Table1'[Status] = NextStatus, 0, IF ( ISBLANK ( LastStatus ) && 'Table1'[Status] <> NextStatus, 2, IF ( ISBLANK ( NextStatus ) && 'Table1'[Status] = lastStatus, 0, IF ( ISBLANK ( NextStatus ) && 'Table1'[Status] <> lastStatus, 1, IF ( 'Table1'[Status] = NextStatus && 'Table1'[Status] = lastStatus, 0, IF ( 'Table1'[Status] = lastStatus && 'Table1'[Status] <> NextStatus, 2, IF ( 'Table1'[Status] <> lastStatus && 'Table1'[Status] <> NextStatus, 3 ) ) ) ) ) ) )
Best Regards!
Dale
Hi @Sir_night,
It's obviously there is an order of "Date" for a "Ref" in your scenario. So let's sort the data first, then add an index to keep the orders. Finally, we just need to compare "Status" between "index" and "index + 1".
1. Open "Query Editor", do "Sort Ascending" of "Ref", then do "Sort Ascending" of "Date". There will be two arrows. (blue rectangle). Please don't break the order of ordering. "Ref" first, "Date" second.
2. Add an index.
3. Add a calculated column.
Status changed = VAR NextStatus = CALCULATE ( VALUES ( Table1[Status] ), FILTER ( ALL ( 'Table1' ), 'Table1'[Ref] = EARLIER ( Table1[Ref] ) && 'Table1'[Index] = EARLIER ( Table1[Index] ) - 1 ) ) RETURN IF ( ISBLANK ( NextStatus ), 0, IF ( 'Table1'[Status] = NextStatus, 0, 1 ) )
Best Regards!
Dale
Hi Dale
is there any way to modify this to mark both the changed record and the prevouse record
thanks for your help
David
Hi David,
It would be a little complicated.
Method 1: Add a new column, tag the previous record only. (depend on [Status changed])
Status changed = VAR NextStatus = CALCULATE ( VALUES ( Table1[Status] ), FILTER ( ALL ( 'Table1' ), 'Table1'[Ref] = EARLIER ( Table1[Ref] ) && 'Table1'[Index] = EARLIER ( Table1[Index] ) - 1 ) ) RETURN IF ( ISBLANK ( NextStatus ), 0, IF ( 'Table1'[Status] = NextStatus, 0, 1 ) )
Method 2: there are four statuses here. (independant)
0 isn't changed and isn't previous
1 changed and isn't previous
2 isn't changed and previous
3 changed and previous
StatusFlag = VAR LastStatus = CALCULATE ( VALUES ( Table1[Status] ), FILTER ( ALL ( 'Table1' ), 'Table1'[Ref] = EARLIER ( Table1[Ref] ) && 'Table1'[Index] = EARLIER ( Table1[Index] ) - 1 ) ) VAR NextStatus = CALCULATE ( VALUES ( Table1[Status] ), FILTER ( ALL ( 'Table1' ), 'Table1'[Ref] = EARLIER ( Table1[Ref] ) && 'Table1'[Index] = EARLIER ( Table1[Index] ) + 1 ) ) RETURN IF ( ISBLANK ( LastStatus ) && 'Table1'[Status] = NextStatus, 0, IF ( ISBLANK ( LastStatus ) && 'Table1'[Status] <> NextStatus, 2, IF ( ISBLANK ( NextStatus ) && 'Table1'[Status] = lastStatus, 0, IF ( ISBLANK ( NextStatus ) && 'Table1'[Status] <> lastStatus, 1, IF ( 'Table1'[Status] = NextStatus && 'Table1'[Status] = lastStatus, 0, IF ( 'Table1'[Status] = lastStatus && 'Table1'[Status] <> NextStatus, 2, IF ( 'Table1'[Status] <> lastStatus && 'Table1'[Status] <> NextStatus, 3 ) ) ) ) ) ) )
Best Regards!
Dale
@Sir_night do you have a status change date, to be honest that would be your best bet is have some sort of indicator when its changed.
Power bi is not really a database, its a data visualisation tool, so doing this sort of thing is better done at source or with the right data coming into the model.
In a real world scenario you would need to snapshot the data in order to compare old to new.
Proud to be a Super User!
This is your chance to engage directly with the engineering team behind Fabric and Power BI. Share your experiences and shape the future.
Check out the June 2025 Power BI update to learn about new features.
User | Count |
---|---|
56 | |
54 | |
54 | |
37 | |
29 |
User | Count |
---|---|
78 | |
64 | |
45 | |
40 | |
40 |