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

The Power BI Data Visualization World Championships is back! It's time to submit your entry. Live now!

Reply
Jaromir
Frequent Visitor

Memory issue - IF using calculated measure

Hi,

 

I am trying to calculate a day by day difference in stock values. To do that I have created a calculated measure called PrevStock:

 

PrevStock = CALCULATE(SUM('data'[stock]); PREVIOUSDAY('data'[date].[Date]))

 

Based on that measure I can calculate the difference between stocks in the consecutive days (measure):

 

Change = sum('data'[stock]) - 'data'[PrevStock]

 

Then I want to display data for a particular month, say February. The problem I am facing is that on 1st Feb "Change" shows a number which is equal to stock amount. I guess when I limit date range it cannot see any previous data so it thinks that "PrevStock" is 0.

 

I have tried to use IF statement:

Change = IF('data'[PrevStock] = 0; 0; sum('data'[stock]) - 'data'[PrevStock])

 

But it always runs out of memory. Why is that? How can I solve this? Thanks a lot!

 

Sample data:

2017-02-17 19_59_03.png

1 ACCEPTED SOLUTION
CahabaData
Memorable Member
Memorable Member

You might consider approaching it in the data model as follows:

* make a duplicate table T2

* in T2 make a calculated column that is (date less 1): PriorDate

 

Now join your Table to T2 using T1 date field and T2 PriorDate; or possibly even consider a merged table of the two - - kind of thinking out loud here....

 

* to avoid confusion in field names of T1 and T2 together you might change column name of T2 Stock to PriorStock

 

via Related method (or possibly the merged table) now you have Stock and Prior Stock in the same record and getting the difference is at your finger tips

www.CahabaData.com

View solution in original post

2 REPLIES 2
CahabaData
Memorable Member
Memorable Member

You might consider approaching it in the data model as follows:

* make a duplicate table T2

* in T2 make a calculated column that is (date less 1): PriorDate

 

Now join your Table to T2 using T1 date field and T2 PriorDate; or possibly even consider a merged table of the two - - kind of thinking out loud here....

 

* to avoid confusion in field names of T1 and T2 together you might change column name of T2 Stock to PriorStock

 

via Related method (or possibly the merged table) now you have Stock and Prior Stock in the same record and getting the difference is at your finger tips

www.CahabaData.com
MattAllington
Community Champion
Community Champion

Dax is not good at row by row comparisons. Take a look at my article here. 

http://exceleratorbi.com.au/use-power-query-compare-database-records/



* Matt is an 8 times Microsoft MVP (Power BI) and author of the Power BI Book Supercharge Power BI.
I will not give you bad advice, even if you unknowingly ask for it.

Helpful resources

Announcements
Power BI DataViz World Championships

Power BI Dataviz World Championships

The Power BI Data Visualization World Championships is back! It's time to submit your entry.

January Power BI Update Carousel

Power BI Monthly Update - January 2026

Check out the January 2026 Power BI update to learn about new features.

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.