Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.

Reply
jimpatel
Helper V
Helper V

3 m rolling

Hi,

 

Thanks for looking at my post.

 

I got stuck with 3 months rolling formula and any help will be much appreciated.

 

I have data and i wanted to sum the rolling 3 months please. 

In this instance in below data, 

 

3M rolling for Mar 2024 will be 35 ( 30 + 3 +2)

3M rolling for Feb 2024 will be 30 (3+2+25)

3M rolling for Jan 2024 will be 27 (0+25+2) and so on....

 

Data snapshot:

 

jimpatel_0-1714471099945.png

 

3m rolling which is wrong:

jimpatel_1-1714471131119.png

 

Formula used for 3m rolling :

jimpatel_2-1714471150076.png

 

any idea please?

 

thanks a lot

 

1 ACCEPTED SOLUTION
v-yangliu-msft
Community Support
Community Support

 

Thanks for the reply from @aduguid , please allow me to provide another insight:

 

Hi  @jimpatel ,

Here are the steps you can follow:

1. Create measure.

Value =
IF(    MAX('Table'[Date])=MINX(FILTER(ALL('Table'),YEAR('Table'[Date])=YEAR(MAX('Table'[Date]))&&MONTH('Table'[Date])=MONTH(MAX('Table'[Date]))),[Date]),
    SUMX('Table',[Total]),0)
3 m rolling =
var _enddate=EOMONTH(MAX('Table'[Date]),0)
var _startdate=EOMONTH(MAX('Table'[Date]),-3)
RETURN
SUMX(
    FILTER(ALL('Table'),
    'Table'[Date]>=_startdate&&'Table'[Date]<=_enddate),
[Value])

2. Result:

vyangliumsft_0-1714542165263.png

 

 

Best Regards,

Liu Yang

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly

View solution in original post

8 REPLIES 8
v-yangliu-msft
Community Support
Community Support

 

Thanks for the reply from @aduguid , please allow me to provide another insight:

 

Hi  @jimpatel ,

Here are the steps you can follow:

1. Create measure.

Value =
IF(    MAX('Table'[Date])=MINX(FILTER(ALL('Table'),YEAR('Table'[Date])=YEAR(MAX('Table'[Date]))&&MONTH('Table'[Date])=MONTH(MAX('Table'[Date]))),[Date]),
    SUMX('Table',[Total]),0)
3 m rolling =
var _enddate=EOMONTH(MAX('Table'[Date]),0)
var _startdate=EOMONTH(MAX('Table'[Date]),-3)
RETURN
SUMX(
    FILTER(ALL('Table'),
    'Table'[Date]>=_startdate&&'Table'[Date]<=_enddate),
[Value])

2. Result:

vyangliumsft_0-1714542165263.png

 

 

Best Regards,

Liu Yang

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly

Sorry for reopening this post.

May i know how to change below formula please.

 

* This formula is summing data if it is falling on same day. That is i wanted to take one value or average value if it is falling on same date please.  Any help will be highly appreciated.

 

Value = IF( MAX('Table'[Date])=MINX(FILTER(ALL('Table'),YEAR('Table'[Date])=YEAR(MAX('Table'[Date]))&&MONTH('Table'[Date])=MONTH(MAX('Table'[Date]))),[Date]), SUMX('Table',[Total]),0)

 

The reason i found is , if 2 rows fall in the minimum criteria the code is adding those values. Is there anyway to not to do that pleasE?

 

jimpatel_0-1716300845495.png

 

Thanks a lot 

 

 

Perfect

 

Thanks a lot for your kind help 🙂

jimpatel
Helper V
Helper V

Any idea of where i am going wrong please?

 

Thanks a lot again

jimpatel
Helper V
Helper V

Much appreciated but i am getting below

jimpatel_0-1714478603466.png

 

May i know what i am doing wrong pleasE?

 

Thanks a lot

aduguid
Resolver II
Resolver II

 

RollingSum3Months = 
VAR CurrentDate = MAX('YourDateColumn')
RETURN
    CALCULATE(
        SUM('YourValueColumn'),
        DATESINPERIOD (
           Calendar[Date],
           LASTDATE ( PREVIOUSMONTH ( Calendar[Date] ) ),
           -3, MONTH
    )
    )

 

Thanks for your reply.

 

But i am still getting wrong answer. Am i doing anything wrong here pleasE?

 

I have used above formula in both column and measure and still no luck 😞

jimpatel_0-1714476166613.png

 

 

 

I've updated my answer. Hope this helps.

Helpful resources

Announcements
RTI Forums Carousel3

New forum boards available in Real-Time Intelligence.

Ask questions in Eventhouse and KQL, Eventstream, and Reflex.

LearnSurvey

Fabric certifications survey

Certification feedback opportunity for the community.

Top Solution Authors