- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Printer Friendly Page
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content

Help with evaluating some DAX code
Hi,
I'm struggling to work out how this piece of code is being being evaluated, in particular what is being calculated first, second and so on. If some could break it down to show what each step is in order it would be a great help.
Also, Is there a way of making this code simpler using Variables?
Days ERT to Outcome =
IF (
NOT ( ISBLANK ( 'Cases'[ERT Start FlagDate] )),
IF (
ISBLANK ( 'Cases'[formofauthorityreceiveddate] ),
DATEDIFF (
IF (
'Cases'[Created Date] > 'Cases'[ERT Start FlagDate],
'Cases'[Created on],
'Cases'[ERT Start FlagDate]
),
IF ( ISBLANK ( 'Cases'[ERT End FlagDate] ), NOW (), 'Cases'[ERT End FlagDate] ),
DAY
),
DATEDIFF ( 'Cases'[ERT Start FlagDate], 'Cases'[ERT End FlagDate], DAY )
),
BLANK ()
)
Thanks,
Solved! Go to Solution.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content

IF statements work from the top in so it check 1, the 2 etc:
It startts with 1 and IF 'Cases[ERT Start Flag Date] is not blank it goes to section A which starts the 2 check, if it is blank it gos to B and returns a BLANK().
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content

Hi @ArchStanton
The explanation from @jdbuchanan71 is perfect. Regarding your second question, you can use variables in this way:
Days ERT to Outcome =
var _startFlag= ISBLANK ( 'Cases'[ERT Start FlagDate] )
var _endFlag= ISBLANK ( 'Cases'[ERT End FlagDate] )
IF (
NOT ( _startFlag),
IF (
ISBLANK ( 'Cases'[formofauthorityreceiveddate] ),
DATEDIFF (
IF (
'Cases'[Created Date] > 'Cases'[ERT Start FlagDate],
'Cases'[Created on],
'Cases'[ERT Start FlagDate]
),
IF ( _endFlag , NOW (), 'Cases'[ERT End FlagDate] ),
DAY
),
DATEDIFF ( 'Cases'[ERT Start FlagDate], 'Cases'[ERT End FlagDate], DAY )
),
BLANK ()
)
However, as you can see, it doesn't make much sense. Variables avoid repetitive calculus, but in this case, you don't have repetitive pieces
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content

IF statements work from the top in so it check 1, the 2 etc:
It startts with 1 and IF 'Cases[ERT Start Flag Date] is not blank it goes to section A which starts the 2 check, if it is blank it gos to B and returns a BLANK().
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content

Hi @ArchStanton
The explanation from @jdbuchanan71 is perfect. Regarding your second question, you can use variables in this way:
Days ERT to Outcome =
var _startFlag= ISBLANK ( 'Cases'[ERT Start FlagDate] )
var _endFlag= ISBLANK ( 'Cases'[ERT End FlagDate] )
IF (
NOT ( _startFlag),
IF (
ISBLANK ( 'Cases'[formofauthorityreceiveddate] ),
DATEDIFF (
IF (
'Cases'[Created Date] > 'Cases'[ERT Start FlagDate],
'Cases'[Created on],
'Cases'[ERT Start FlagDate]
),
IF ( _endFlag , NOW (), 'Cases'[ERT End FlagDate] ),
DAY
),
DATEDIFF ( 'Cases'[ERT Start FlagDate], 'Cases'[ERT End FlagDate], DAY )
),
BLANK ()
)
However, as you can see, it doesn't make much sense. Variables avoid repetitive calculus, but in this case, you don't have repetitive pieces
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content

Really grateful for your reply as well, many thanks

Helpful resources
Join us at the Microsoft Fabric Community Conference
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!
Power BI Monthly Update - February 2025
Check out the February 2025 Power BI update to learn about new features.

Subject | Author | Posted | |
---|---|---|---|
09-19-2024 12:47 AM | |||
07-11-2024 12:51 AM | |||
08-09-2024 01:56 AM | |||
09-11-2024 12:54 AM | |||
12-11-2023 03:48 PM |
User | Count |
---|---|
87 | |
81 | |
53 | |
38 | |
35 |