Power BI is turning 10! Tune in for a special live episode on July 24 with behind-the-scenes stories, product evolution highlights, and a sneak peek at what’s in store for the future.
Save the dateEnhance your career with this limited time 50% discount on Fabric and Power BI exams. Ends August 31st. Request your voucher.
Solved! Go to Solution.
Hi @tberr86
As you've rightly said, RELATED is not required here. RELATED requires a row context which does not exist in a measure (unless introduced within the measure by an iterator). In any case, filters applied to tables on the 1-side of a 1:many relationship automatically "propogate" from the 1-side to the many-side table.
I would also suggest CALCULATE ( COUNTROWS (...) ) rather than COUNTROWS ( CALCULATETABLE (...) )
Also, since the "Q75" filter is common to both components of the measure, you could use an outer CALCULATE with that filter applied, and place the remaining filters within nested CALCULATE calls.
Putting all this together, you could write something like this:
Total WIP =
CALCULATE (
VAR ActiveWIP =
CALCULATE (
COUNTROWS ( 'SCHEDHOUSEDETAIL' ),
ISBLANK ( 'SCHEDHOUSEDETAIL'[actualfinishdate] )
)
VAR UnsoldCompletedHomes =
CALCULATE (
COUNTROWS ( 'SCHEDHOUSEDETAIL' ),
NOT ISBLANK ( 'SCHEDHOUSEDETAIL'[actualfinishdate] ),
ISBLANK ( 'HOUSE MASTER'[contract_date] ),
NOT ISBLANK ( 'HOUSE MASTER'[Start Date] )
)
RETURN
ActiveWIP + UnsoldCompletedHomes,
'SCHEDHOUSEDETAIL'[activitycode] = "Q75"
)
Alternatively, you could create two separate measures for ActiveWIP and UnsoldCompleteHomes, and sum them in the Total WIP.
Does the above measure give the expected result?
Regards,
Owen
Hi @tberr86
As you've rightly said, RELATED is not required here. RELATED requires a row context which does not exist in a measure (unless introduced within the measure by an iterator). In any case, filters applied to tables on the 1-side of a 1:many relationship automatically "propogate" from the 1-side to the many-side table.
I would also suggest CALCULATE ( COUNTROWS (...) ) rather than COUNTROWS ( CALCULATETABLE (...) )
Also, since the "Q75" filter is common to both components of the measure, you could use an outer CALCULATE with that filter applied, and place the remaining filters within nested CALCULATE calls.
Putting all this together, you could write something like this:
Total WIP =
CALCULATE (
VAR ActiveWIP =
CALCULATE (
COUNTROWS ( 'SCHEDHOUSEDETAIL' ),
ISBLANK ( 'SCHEDHOUSEDETAIL'[actualfinishdate] )
)
VAR UnsoldCompletedHomes =
CALCULATE (
COUNTROWS ( 'SCHEDHOUSEDETAIL' ),
NOT ISBLANK ( 'SCHEDHOUSEDETAIL'[actualfinishdate] ),
ISBLANK ( 'HOUSE MASTER'[contract_date] ),
NOT ISBLANK ( 'HOUSE MASTER'[Start Date] )
)
RETURN
ActiveWIP + UnsoldCompletedHomes,
'SCHEDHOUSEDETAIL'[activitycode] = "Q75"
)
Alternatively, you could create two separate measures for ActiveWIP and UnsoldCompleteHomes, and sum them in the Total WIP.
Does the above measure give the expected result?
Regards,
Owen
Thank you! Not just for the solution but for the explaination, really helped clarify how the functions work.
User | Count |
---|---|
22 | |
11 | |
8 | |
6 | |
6 |
User | Count |
---|---|
25 | |
12 | |
11 | |
7 | |
6 |