Advance your Data & AI career with 50 days of live learning, dataviz contests, hands-on challenges, study groups & certifications and more!
Get registeredJoin us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM. Register now.
Hello everyone,
I've been trying to get my matrix to aggregate data for years prior or later than this year together. While data from this year is broken down to months Like this:
2022 | 2022 | 2022 | 2022 | 2022 | 2022 | 2022 | 2022 | 2022 | 2022 | 2022 | 2022 | |||
| Prior to 2022 | January | February | March | April | May | June | July | August | September | October | November | December | later than 2022 |
SC | 2 | 2 | 9 | 1 | 1 | 1 | 5 | 5 | 11 | 4 | 11 | 4 | 5 | |
WA | 28 | 3 | 0 | 0 | 4 | 1 | 0 | 1 | 0 | 6 | 4 | 9 | 7 |
Is this even a possibility?
Solved! Go to Solution.
See if this works for you. You need to create a table which has the layout you need. In my example I have a date table, so I am creating the Matrix Layout table referencing the Date Table and adding the Prior and After rows as follows:
Matrix Layout =
VAR _Current =
CALCULATETABLE (
SUMMARIZE (
'Date Table',
'Date Table'[Year],
'Date Table'[Month],
'Date Table'[MonthNum]
),
'Date Table'[Year] = YEAR ( TODAY () )
)
VAR _otherPeriods =
{ ( "Prior to", YEAR ( TODAY () ), 0 ), ( "After", YEAR ( TODAY () ), 13 ) }
RETURN
UNION ( _Current, _otherPeriods )
Once the table is loaded, I'm adding a sorting order for the "Year" column using:
Sort =
SWITCH(
'Matrix Layout'[MonthNum],
0,1,
13, 3,
2)
To get:
The model is as follows:
Sort the "Year" column by "Sort"; Sort the "Month" column by "MonthNum" column.
Create the following measure (I'm using a simple SUM for the calculations, so use whatever you need)
Final Measure =
VAR _Prior =
CALCULATE (
[Sum Sales],
FILTER ( ALL ( 'Date Table' ), 'Date Table'[Year] < YEAR ( TODAY () ) )
)
VAR _After =
CALCULATE (
[Sum Sales],
FILTER ( ALL ( 'Date Table' ), 'Date Table'[Year] > YEAR ( TODAY () ) )
)
VAR _Current =
CALCULATE (
[Sum Sales],
TREATAS ( VALUES ( 'Matrix Layout'[Month] ), 'Date Table'[Month] ),
FILTER ( 'Date Table', 'Date Table'[Year] = YEAR ( TODAY () ) )
)
RETURN
SWITCH (
SELECTEDVALUE ( 'Matrix Layout'[MonthNum] ),
0, _Prior,
13, _After,
_Current
)
Now create the matrix visual with the fields from the Matrix Layout table, whatever you need as rows and the [Final measure] to get:
I've attached the sample PBIX file
Proud to be a Super User!
Paul on Linkedin.
Does the year selection need to be dynamic or is it always going to be the current year?
Proud to be a Super User!
Paul on Linkedin.
Hi Paul,
So the current year will always be the one broken down into months. So by the next year 2023 would be broken down and 2022 will be aggregated with the previous years (2021, 2020, etc).
Thanks for trying to help out
See if this works for you. You need to create a table which has the layout you need. In my example I have a date table, so I am creating the Matrix Layout table referencing the Date Table and adding the Prior and After rows as follows:
Matrix Layout =
VAR _Current =
CALCULATETABLE (
SUMMARIZE (
'Date Table',
'Date Table'[Year],
'Date Table'[Month],
'Date Table'[MonthNum]
),
'Date Table'[Year] = YEAR ( TODAY () )
)
VAR _otherPeriods =
{ ( "Prior to", YEAR ( TODAY () ), 0 ), ( "After", YEAR ( TODAY () ), 13 ) }
RETURN
UNION ( _Current, _otherPeriods )
Once the table is loaded, I'm adding a sorting order for the "Year" column using:
Sort =
SWITCH(
'Matrix Layout'[MonthNum],
0,1,
13, 3,
2)
To get:
The model is as follows:
Sort the "Year" column by "Sort"; Sort the "Month" column by "MonthNum" column.
Create the following measure (I'm using a simple SUM for the calculations, so use whatever you need)
Final Measure =
VAR _Prior =
CALCULATE (
[Sum Sales],
FILTER ( ALL ( 'Date Table' ), 'Date Table'[Year] < YEAR ( TODAY () ) )
)
VAR _After =
CALCULATE (
[Sum Sales],
FILTER ( ALL ( 'Date Table' ), 'Date Table'[Year] > YEAR ( TODAY () ) )
)
VAR _Current =
CALCULATE (
[Sum Sales],
TREATAS ( VALUES ( 'Matrix Layout'[Month] ), 'Date Table'[Month] ),
FILTER ( 'Date Table', 'Date Table'[Year] = YEAR ( TODAY () ) )
)
RETURN
SWITCH (
SELECTEDVALUE ( 'Matrix Layout'[MonthNum] ),
0, _Prior,
13, _After,
_Current
)
Now create the matrix visual with the fields from the Matrix Layout table, whatever you need as rows and the [Final measure] to get:
I've attached the sample PBIX file
Proud to be a Super User!
Paul on Linkedin.
Hi Paul!
Thank you so very much, It worked!
One small thing though, I couldn't sort the month name by month number. Cause the value "2022" is repeated twice in column Month name. I get this error:
This is what the final table looks like:
How did you get your to sort?
Of course...you're right. It cannot sort beacuase there are two rows with 2022. This may actually be a bug. Let me explain. Originally I built the Matrix Layout with both the "Prior to 2022" and "after 2022" in the Month column. I did the sorting to see the visual. I then decided to move the "pior to" and "After " texts to the Year column, That's probably why it is still sorting the months correctly.
Anyway, an easy fix. Use this codefor the Matrix Layout table and you should be able to sort the months correctly (you also need the "sort" column for the years)
Matrix Layout =
VAR _Current =
CALCULATETABLE (
SUMMARIZE (
'Date Table',
'Date Table'[Year],
'Date Table'[Month],
'Date Table'[MonthNum]
),
'Date Table'[Year] = YEAR ( TODAY () )
)
VAR _otherPeriods =
{
( "Prior", "to " & YEAR ( TODAY () ), 0 ),
( "After", YEAR ( TODAY () ), 13 )
}
RETURN
UNION ( _Current, _otherPeriods )
Proud to be a Super User!
Paul on Linkedin.
That explains it. Thanks again for your support!
You know what I just changed things up a little to make it work:
Final matrix:
Thanks a lot
Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes!
Check out the October 2025 Power BI update to learn about new features.
User | Count |
---|---|
79 | |
38 | |
31 | |
27 | |
27 |