March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early bird discount ends December 31.
Register NowBe one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now
Hi, below DAX does not display correct result. What this code should be doing is displaying "RPMD" for previous 10 periods. Each period is a week. I suspect the problem lands possibly caused by misusing of CALCULATE, FILTER and ALL. Please advise.
RPMD Last 10 =
VAR _selecteddate =
MIN ( 'Calendar'[Date] )
RETURN
CALCULATE (
[RPMD],
FILTER (
ALL ( 'Calendar'[Date] ),
IF (
'Calendar'[Date] = _selecteddate - 7,
'Calendar'[Date],
IF (
'Calendar'[Date] = _selecteddate - 14,
'Calendar'[Date],
IF (
'Calendar'[Date] = _selecteddate - 21,
'Calendar'[Date],
IF (
'Calendar'[Date] = _selecteddate - 28,
'Calendar'[Date],
IF (
'Calendar'[Date] = _selecteddate - 35,
'Calendar'[Date],
IF (
'Calendar'[Date] = _selecteddate - 42,
'Calendar'[Date],
IF (
'Calendar'[Date] = _selecteddate - 49,
'Calendar'[Date],
IF (
'Calendar'[Date] = _selecteddate - 56,
'Calendar'[Date],
IF (
'Calendar'[Date] = _selecteddate - 63,
'Calendar'[Date],
IF ( 'Calendar'[Date] = _selecteddate, 'Calendar'[Date], BLANK () )
)
)
)
)
)
)
)
)
)
)
)
Solved! Go to Solution.
@anubb688 Probably, Why not just get the current date and if you want the past 10 periods (each a week) then something like:
RPMD Last 10 =
VAR __SelectedDate = MIN('Calendar'[Date])
VAR __10Prior = __SelectedDate - 70
RETURN
CALCULATE([RPMD],FILTER('Calendar','Calendar'[Date]>=__10Prior && 'Calendar'[Date]<=__SelectedDate))
@anubb688 Probably, Why not just get the current date and if you want the past 10 periods (each a week) then something like:
RPMD Last 10 =
VAR __SelectedDate = MIN('Calendar'[Date])
VAR __10Prior = __SelectedDate - 70
RETURN
CALCULATE([RPMD],FILTER('Calendar','Calendar'[Date]>=__10Prior && 'Calendar'[Date]<=__SelectedDate))
It somehow shows a dot instead of line chart which i have selected
Maybe:
RPMD Last 10 =
VAR __SelectedDate = MIN('Calendar'[Date])
VAR __10Prior = __SelectedDate - 70
RETURN
CALCULATE([RPMD],FILTER(ALL('Calendar'),'Calendar'[Date]>=__10Prior && 'Calendar'[Date]<=__SelectedDate))
It's really hard to know with such incomplete information.
Your code worked when I tweaked my beneath formulas. Thanks. I'll mark yours as solution since I found my direction.
User | Count |
---|---|
21 | |
14 | |
11 | |
8 | |
5 |
User | Count |
---|---|
24 | |
21 | |
20 | |
15 | |
10 |