Power BI is turning 10, and we’re marking the occasion with a special community challenge. Use your creativity to tell a story, uncover trends, or highlight something unexpected.
Get startedJoin us for an expert-led overview of the tools and concepts you'll need to become a Certified Power BI Data Analyst and pass exam PL-300. Register now.
I have a request to show data in 3 month periods,
there will be sale that started in 2016 but closed in 2022, so we need to show this as 72 months,
this will be calculated with each year starting from q1 = 3 Months, q2 = 6 Months, q3 = 9 Months and so on,.
E.g
How can this be done using dax ?
or is it better to go to sql to calculate this?
Solved! Go to Solution.
Hi @MartinDra .
You can try this method:
I create two sample tables in two years, Period table and Sales table.
Then we need to calculate the year and the quarter:
New columns:
Year = YEAR('Sales'[Date])
Quar = QUARTER('Sales'[Date])
Then
Var = 'Sales'[Year] - MIN('Sales'[Year])
Index = 'Sales'[Var] * 4 + Sales[Quar]
SUMEVERYQ =
CALCULATE (
SUM ( Sales[Sales] ),
FILTER (
'Sales',
'Sales'[Year] = EARLIER ( Sales[Year] )
&& 'Sales'[Quar] = EARLIER ( Sales[Quar] )
)
)
For the period table,
New a column:
M = MID('Period'[Period],1,2) / 3
The M column need to change to the whole number format.
The result column is :
Result =
CALCULATE (
AVERAGE ( Sales[SUMEVERYQ] ),
FILTER ( 'Sales', 'Sales'[Index] = 'Period'[M] )
)
Hope these help you.
Here is my PBIX file.
Best Regards,
Community Support Team _Yinliw
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Hi,
thanks. I think its close but not exactly what I need.
I need an ability to show year as well.
so we can see progression over time,
if I just have the period it only we are limited with the number of months since begining.
So in Data Warehouse side it isnt going to work.
Any ideas on how to achieve the above?
Hi @MartinDra .
You can try this method:
I create two sample tables in two years, Period table and Sales table.
Then we need to calculate the year and the quarter:
New columns:
Year = YEAR('Sales'[Date])
Quar = QUARTER('Sales'[Date])
Then
Var = 'Sales'[Year] - MIN('Sales'[Year])
Index = 'Sales'[Var] * 4 + Sales[Quar]
SUMEVERYQ =
CALCULATE (
SUM ( Sales[Sales] ),
FILTER (
'Sales',
'Sales'[Year] = EARLIER ( Sales[Year] )
&& 'Sales'[Quar] = EARLIER ( Sales[Quar] )
)
)
For the period table,
New a column:
M = MID('Period'[Period],1,2) / 3
The M column need to change to the whole number format.
The result column is :
Result =
CALCULATE (
AVERAGE ( Sales[SUMEVERYQ] ),
FILTER ( 'Sales', 'Sales'[Index] = 'Period'[M] )
)
Hope these help you.
Here is my PBIX file.
Best Regards,
Community Support Team _Yinliw
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
This is your chance to engage directly with the engineering team behind Fabric and Power BI. Share your experiences and shape the future.
Check out the June 2025 Power BI update to learn about new features.
User | Count |
---|---|
61 | |
56 | |
55 | |
36 | |
34 |
User | Count |
---|---|
77 | |
73 | |
45 | |
45 | |
43 |