cancel
Showing results for
Did you mean:
Helper I

## DAX VAR Function

Hi All,

I am trying to get a VAR formula to work to avoid having multiple measures to calculate Turnover.

Currently I have five measures to calculate Turnover (see below), I am hoping to reduce that to one with VAR.

• Centre Terminations
• Centre Terminations 12MTD
• Centre Turnover

Invidually they all work however when I put them in one formula I get 0%.

This is how I have done my test Measure:

``````TEST =
VAR CentreHeadcount = CALCULATE(COUNT('Centre Employees'[Employee ID]),'Calendar'[Month Offset]>0)
VAR CentreTerminations = CALCULATE(DISTINCTCOUNT('Centre Terminations'[Employee ID]),'Calendar'[Month Offset]>0)

return

VAR Terminations12MTD = CALCULATE(CentreTerminations,DATESINPERIOD('Calendar'[Date],LASTDATE('Calendar'[Date]),-12, MONTH),'Calendar'[Month Offset]>0)

return

As mentioned each of these steps work on their own however once put into one equation they don't.

5 REPLIES 5
Helper I

@Greg_Deckler  @Anonymous

Any suggestions as to how I can improve these Measures?

My aim is to have them reduced from 5 to 1 and refrain from using ALLSELECTED if that isn't advisable, I provided a sample file in an earlier post.

Anonymous
Not applicable

It'll give you an idea about the function and why it should be used wisely.

Best
D
Anonymous
Not applicable

Hi there.

I'd like to first kindly ask you: Do not create monster formulas. It's not fun, I assure you, especially for those who will have to maintain such code. Also, please format your measures when you post them on the forum. Please respect your readers' time. Thanks.

Now I'll tell you why your monster does not work. It's because variables to which you've assigned values are STATIC. They cannot be changed. Here's your measure formatted (www.daxformatter.com😞

``````TEST =
CALCULATE (
COUNT ( 'Centre Employees'[Employee ID] ),
'Calendar'[Month Offset] > 0
)
VAR CentreTerminations =
CALCULATE (
DISTINCTCOUNT ( 'Centre Terminations'[Employee ID] ),
'Calendar'[Month Offset] > 0
)
VAR Terminations12MTD =
CALCULATE (
CentreTerminations, -- STATIC VALUE!!!
DATESINPERIOD ( 'Calendar'[Date], LASTDATE ( 'Calendar'[Date] ), -12, MONTH ),
'Calendar'[Month Offset] > 0
)
CALCULATE (
AVERAGEX ( ALLSELECTED ( 'Calendar' ), CentreHeadcount ), -- = CENTREHEADCOUNT always or BLANK
DATESINPERIOD ( 'Calendar'[Date], LASTDATE ( 'Calendar'[Date] ), -12, MONTH ),
'Calendar'[Month Offset] > 0
)
RETURN
CALCULATE (
IF (
DIVIDE ( Terminations12MTD, Headcount12MTD ) = BLANK (),
0,
),
'Calendar'[Month Offset] > 0
)
``````

Also, there's no need to have multiple RETURNs in there. This only obscures the code.

By the way, ALLSELECTED is a very complex function. The most complex function in whole DAX. Do you fully understand what it does? Do you know what shadow context is? I'll give you a hint that will save your life: Please never use in your code something the functionality of which you don't fully understand. If you do use it, you'll be having countless bugs, many of which you'll not be even aware of.

Best

D

Super User

``````TEST =
VAR CentreHeadcount = CALCULATE(COUNT('Centre Employees'[Employee ID]),'Calendar'[Month Offset]>0)
VAR CentreTerminations = CALCULATE(DISTINCTCOUNT('Centre Terminations'[Employee ID]),'Calendar'[Month Offset]>0)

return

VAR Terminations12MTD = CALCULATE(CentreTerminations,DATESINPERIOD('Calendar'[Date],LASTDATE('Calendar'[Date]),-12, MONTH),'Calendar'[Month Offset]>0)

return
Terminations12MTD

So, see if that value is BLANK and if it is that would explain why you are getting 0% back

Become an expert!: Enterprise DNA
External Tools: MSHGQM
Latest book!:
Learn Power BI 2nd Edition
Helper I

Thanks for your response, sorry for the late reply I have been away this weekend.

I have created a dummy file which should be of use.

My aim is to reduce the Centre Turnover KPI to just one Measure instead of having five.

@Anonymous  no I am not fully aware of ALLSELECTED and its limitations so more than happy for that to be adjusted.

Announcements