This time we’re going bigger than ever. Fabric, Power BI, SQL, AI and more. We're covering it all. You won't want to miss it.
Learn moreDid you hear? There's a new SQL AI Developer certification (DP-800). Start preparing now and be one of the first to get certified. Register now
Hi! I have two sources of data like the following, in a one to many relationship using ID:
Data
| ID | Value |
| XY | $1 |
| AB | $2 |
| CZ | $3 |
Activities
| Status | ID |
| Complete | AB |
| In Progress | XY |
| Waiting | XY |
| Complete | AB |
| Waiting | CZ |
| Complete | XY |
| Complete | CZ |
I would like to have a single value in Data for Status, so that In Progress will be shown if there is any to the corresponding ID, otherwise Waiting, and if neither then Complete, as follows:
Data
| ID | Value | Status |
| XY | $1 | In Progress |
| AB | $2 | Complete |
| CZ | $3 | Waiting |
The goal is to display this in a table in the report, highlighting the progress of connected activities. There are 6 different status types (not started, etc). Essentially I want a column like this in Data, but don't know the formula:
IF 'Activities'[Status] CONTAINS "In Progress", "In Progress", IF Activities'[Status] CONTAINS "Waiting", "Waiting", IF 'Activities'[Status] CONTAINS "Complete", "Complete", ""
Is there a simple way to set this up?
Solved! Go to Solution.
Hi @Alex_ ,
Create a calculated column in Status Table:
Status Check = CALCULATE(CONCATENATEX('Status','Status'[Status],",",'Status'[Status],ASC),ALLEXCEPT('Status','Status'[ID]))Flag Check = LOOKUPVALUE('Status'[Status Check],'Status'[ID],Data[ID])Value Status =
Var Complete=SEARCH("Complete",Data[Flag Check],,-1)
Var InProgress=SEARCH("In Progress",Data[Flag Check],,-1)
Var Waiting=SEARCH("Waiting",Data[Flag Check],,-1)
var check=IF(InProgress<>-1,"In Progress",IF(Waiting<>-1,"Waiting",IF(Complete<>-1,"Complete",BLANK())))
return check
Hi @Alex_ ,
Create a calculated column in Status Table:
Status Check = CALCULATE(CONCATENATEX('Status','Status'[Status],",",'Status'[Status],ASC),ALLEXCEPT('Status','Status'[ID]))Flag Check = LOOKUPVALUE('Status'[Status Check],'Status'[ID],Data[ID])Value Status =
Var Complete=SEARCH("Complete",Data[Flag Check],,-1)
Var InProgress=SEARCH("In Progress",Data[Flag Check],,-1)
Var Waiting=SEARCH("Waiting",Data[Flag Check],,-1)
var check=IF(InProgress<>-1,"In Progress",IF(Waiting<>-1,"Waiting",IF(Complete<>-1,"Complete",BLANK())))
return check
Check out the April 2026 Power BI update to learn about new features.
Sign up to receive a private message when registration opens and key events begin.
If you have recently started exploring Fabric, we'd love to hear how it's going. Your feedback can help with product improvements.
| User | Count |
|---|---|
| 34 | |
| 31 | |
| 25 | |
| 20 | |
| 16 |
| User | Count |
|---|---|
| 60 | |
| 48 | |
| 29 | |
| 23 | |
| 23 |