The ultimate Fabric, Power BI, SQL, and AI community-led learning event. Save €200 with code FABCOMM.
Get registeredEnhance your career with this limited time 50% discount on Fabric and Power BI exams. Ends September 15. Request your voucher.
Please help to calculate/understand properly lastDate and rankDate measures for following simplified example (download) :
Desired result:
Reality (incorrect subtypes):
Why relationship is broken?
How to avoid this cartesian product lines?
My Measure (I commented workaround, because it's kind of postfilter, not prefilter):
rnkDate = VAR t = CALCULATETABLE( VALUES(tstTable[Date]), REMOVEFILTERS(tstTable[Date]) ) RETURN //IF( MAX(tstTable[Amount])<>BLANK(), // WORKAROUND To hide unwantedd rows RANKX( t, LASTDATE(tstTable[Date]) ) //)
P.S. Mess happens only if I use fields from dimensional table dimType[Type] (within one table everything is Ok):
@tamerj1 , thank you for your feedback.
@Anonymous
1. Yes you are right.
2. The issue is related to the filter context. One column of the fact table (the [Date] column) is used in the matrix therefore, it's part of the filter context. In this case the filter context created by the engine is the CROSSJOIN between the SUMMARIZE ( dimType, dimType[Type], dimType[subType] ) and DISTINCT ( tstTable[Date] ) which generates all the possible combinations between the two tables.
When placing a normal aggregation measure in the matrix the engine checks first if the value is blank then it hides it. With RANKX things are different and the reason is that even the balnk value will have a rank (because DAX considers blank as zero in calculations) and the rank cannot be blank rather it will be the samllest or the largest rank value depending on the sort oreder of RANKX.
3. You can upload to DropBox or OneDrive and share the download link.
Hi @Anonymous
Please refer to attached sample file with the solution
lastDate =
CALCULATE (
LASTDATE ( tstTable[Date] ),
REMOVEFILTERS ( tstTable[Date] ),
CROSSFILTER ( tstTable[subType], dimType[subType], BOTH )
)
rnkDate =
VAR t =
CALCULATETABLE (
VALUES ( tstTable[Date] ),
REMOVEFILTERS ( tstTable[Date] )
)
VAR Result =
RANKX(
t,
CALCULATE ( MAX ( tstTable[Date] ) )
)
RETURN
IF (
NOT ISEMPTY ( tstTable ),
Result
)
User | Count |
---|---|
14 | |
12 | |
7 | |
6 | |
5 |
User | Count |
---|---|
28 | |
18 | |
13 | |
7 | |
5 |