DAX 查询 - EARLIER() - 与上一季度比较

DAX Query - EARLIER() - Compare with previous Quarter

我尝试在 DAX 中对多个季度进行比较。

在我们的例子中,我们使用带有平面 table 的 Power Pivot 作为源。 (无星型)

这是一个小例子:

我们的来源是这样的:

这就是我们现在拥有的:

这是我们的预期结果:

我尝试用 EARLIER() 和 EARLIEST() 函数做一些事情,但它肯定不好。 (类似于 MDX LAG() 函数)。 在我们的具体案例中,我们没有明确的日期,我不确定我是否可以使用 ParallelPeriod 函数

SumValuePrevious:=CALCULATE
(
  SUM(Data[Value]);
  FILTER(ALL(Data[Quarter]);
  SUMX
   (
           FILTER(Data; EARLIEST(Data[Quarter]) = Data[Quarter] )
           ; 
           [Value]
   )
)
)

但我得到了相同的结果:

你有什么可以帮我的吗?
非常感谢您的帮助,
阿诺

使用日期的最佳方式是添加日期 table。 那么你可以使用默认的日期函数

Previous Quarter:= CALCULATE(SUM(myTable[myColumn]), PREVIOUSQUARTER('Date'[Date])) 

添加日期table:

Date =
ADDCOLUMNS (
CALENDAR (DATE(2000;1;1); DATE(2025;12;31));
"DateAsInteger"; FORMAT ( [Date]; "YYYYMMDD" );
"Year"; YEAR ( [Date] );
"Monthnumber"; FORMAT ( [Date]; "MM" );
"YearMonthnumber"; FORMAT ( [Date]; "YYYY/MM" );
"YearMonthShort"; FORMAT ( [Date]; "YYYY/mmm" );
"MonthNameShort"; FORMAT ( [Date]; "mmm" );
"MonthNameLong"; FORMAT ( [Date]; "mmmm" );
"DayOfWeekNumber"; WEEKDAY ( [Date] );
"DayOfWeek"; FORMAT ( [Date]; "dddd" );
"DayOfWeekShort"; FORMAT ( [Date]; "ddd" );
"Quarter"; "Q" & FORMAT ( [Date]; "Q" );
"YearQuarter"; FORMAT ( [Date]; "YYYY" ) & "/Q" & FORMAT ( [Date]; "Q" )
)

将你的日期table标记为日期table 用季度的第一个日期替换源中的季度列。 在 table 之间创建关系。