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

Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started

Reply
GSE
Resolver I
Resolver I

DAX Difference - Measure as variable vs. Measure directly in formula

Hi all, 

 

I would like to understand the difference between declaring a measure as a variable vs. using the measure directly in the formula without declaring it as a variable first.

 

What I noticed is that in the first example, the processing time is almost 8 times higher (when not declaring it as a variable) and in the second example the formula throws an error.

 

I know that if a measure is declared as a variable first, it is evaluated in the context of the visual but how is it evaluated when not declared as a variable and why does it take so much longer or throws an error.

 

Example 1

not declared as variable (processing time almost 8 times longer)

GSE_0-1682408884636.jpeg

declared as variable

GSE_1-1682408941882.jpeg

Processing time (first matrix is with declared variable and second matrix is without declared variable)

GSE_2-1682409002405.jpeg

 

 

Example 2

not declared as variable: error

GSE_3-1682409025643.jpeg

 

declared as variable: no error

GSE_4-1682409048046.jpeg

 

1 REPLY 1
lbendlin
Super User
Super User

The fun part here is that "variable"  actually means "constant".  You are basically turning the measure into an immutable value that will now no longer be recomputed in the following computations.

 

Power BI has no concept of (mutable) variables. These are all constants.

Helpful resources

Announcements
July 2024 Power BI Update

Power BI Monthly Update - July 2024

Check out the July 2024 Power BI update to learn about new features.

PBI_Carousel_NL_June

Fabric Community Update - June 2024

Get the latest Fabric updates from Build 2024, key Skills Challenge voucher deadlines, top blogs, forum posts, and product ideas.

Top Solution Authors