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

Grow your Fabric skills and prepare for the DP-600 certification exam by completing the latest Microsoft Fabric challenge.

Reply
ericOnline
Post Patron
Post Patron

Determine MIN date across tables using DAX

I come from the PowerApps world, just getting familiar with DAX and PowerQuery. In PowerApps, to determine the minimum value of a set, I'd write something like:

MIN(value1, value2, value3, etc.)

 

I'm unable to make this work with DAX. 

 

Scenario:

- Timestamp column in 4 different tables

- I need the BEGIN_DATE of my DATE_TABLE to be the earliest timestamp shown in any table

- And END_DATE of DATE_TABLE to be the latest timestamp shown in any table (I'll use MAX for this once I figure out MIN!)

 

Tried:

MIN(table1[ts1], table2[ts2], table3[ts3], etc.). 

But DAX doesn't like the second parameter (nor any parameter thereafter)
What am I missing?

Thank you

2 ACCEPTED SOLUTIONS
V-pazhen-msft
Community Support
Community Support

@ericOnline 

Try something like this if you want the min value of 4 columns:

 

Measure = 
var m= IF(MIN('Table1'[ts1])<=MIN('Table2'[ts2]),MIN('Table1'[ts1]), IF(MIN('Table2'[ts2])<=MIN('Table3'[ts3]),MIN('Table2'[ts2]),MIN('Table3'[ts3])))

Return IF(m<=MIN('Table4'[ts4]),m,MIN('Table4'[ts4]))

 

 

Paul Zheng _ Community Support Team
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

Hi @V-pazhen-msft , 

I was able to translate your solution to my use case. Since I am generating a Date Table based on timestamps in 3 tables, rather than a Measure, here is what I used: (Thank you!)

DATE_TABLE = 
VAR MIN_TS = 
    IF(
        MIN(TABLE1[TIMESTAMP]) <=
        MIN(TABLE2[TIMESTAMP]),
        MIN(TABLE1[TIMESTAMP]),
        IF(
            MIN(TABLE2[TIMESTAMP]) <=
            MIN(TABLE3[TIMESTAMP]),
            MIN(TABLE2[TIMESTAMP]),
            MIN(TABLE3[TIMESTAMP])
        )
    )

VAR MAX_TS = 
    IF(
        MAX(TABLE1[TIMESTAMP]) >=
        MAX(TABLE2[TIMESTAMP]),
        MAX(TABLE1[TIMESTAMP]),
        IF(
            MAX(TABLE2[TIMESTAMP]) >=
            MAX(TABLE3[TIMESTAMP]),
            MAX(TABLE2[TIMESTAMP]),
            MAX(TABLE3[TIMESTAMP])
        )
    )

RETURN

CALENDAR(
    MIN_TS, 
    MAX_TS
)

Sure would be more intuitive if DAX allowed something like:

DATE_TABLE = 
CALENDAR(
    MIN(TABLE1[TIMESTAMP], TABLE2[TIMESTAMP], TABLE3[TIMESTAMP]),
    MAX(TABLE1[TIMESTAMP], TABLE2[TIMESTAMP], TABLE3[TIMESTAMP])
)

 Oh well! Job security!

View solution in original post

5 REPLIES 5
V-pazhen-msft
Community Support
Community Support

@ericOnline 

Try something like this if you want the min value of 4 columns:

 

Measure = 
var m= IF(MIN('Table1'[ts1])<=MIN('Table2'[ts2]),MIN('Table1'[ts1]), IF(MIN('Table2'[ts2])<=MIN('Table3'[ts3]),MIN('Table2'[ts2]),MIN('Table3'[ts3])))

Return IF(m<=MIN('Table4'[ts4]),m,MIN('Table4'[ts4]))

 

 

Paul Zheng _ Community Support Team
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly

Hi @V-pazhen-msft , 

I was able to translate your solution to my use case. Since I am generating a Date Table based on timestamps in 3 tables, rather than a Measure, here is what I used: (Thank you!)

DATE_TABLE = 
VAR MIN_TS = 
    IF(
        MIN(TABLE1[TIMESTAMP]) <=
        MIN(TABLE2[TIMESTAMP]),
        MIN(TABLE1[TIMESTAMP]),
        IF(
            MIN(TABLE2[TIMESTAMP]) <=
            MIN(TABLE3[TIMESTAMP]),
            MIN(TABLE2[TIMESTAMP]),
            MIN(TABLE3[TIMESTAMP])
        )
    )

VAR MAX_TS = 
    IF(
        MAX(TABLE1[TIMESTAMP]) >=
        MAX(TABLE2[TIMESTAMP]),
        MAX(TABLE1[TIMESTAMP]),
        IF(
            MAX(TABLE2[TIMESTAMP]) >=
            MAX(TABLE3[TIMESTAMP]),
            MAX(TABLE2[TIMESTAMP]),
            MAX(TABLE3[TIMESTAMP])
        )
    )

RETURN

CALENDAR(
    MIN_TS, 
    MAX_TS
)

Sure would be more intuitive if DAX allowed something like:

DATE_TABLE = 
CALENDAR(
    MIN(TABLE1[TIMESTAMP], TABLE2[TIMESTAMP], TABLE3[TIMESTAMP]),
    MAX(TABLE1[TIMESTAMP], TABLE2[TIMESTAMP], TABLE3[TIMESTAMP])
)

 Oh well! Job security!

CALENDARAUTO() would also give you the result by scanning all tables in your data set with dates and providing the correct range, you can also change the starting month number - for example July with CALENDARAUTO(6)

az38
Community Champion
Community Champion

Hi @ericOnline 

try this technique

MIN(table1[ts1], MIN(table2[ts2], MIN(table2[ts3], table3[ts4])))

 


do not hesitate to give a kudo to useful posts and mark solutions as solution
LinkedIn

@az38 , 

It appears that MIN() only accepts two values. Adding all four table columns in a single MIN() statement results in the error: `Unexpected Parameter` columns 3 and 4. 

Helpful resources

Announcements
Europe Fabric Conference

Europe’s largest Microsoft Fabric Community Conference

Join the community in Stockholm for expert Microsoft Fabric learning including a very exciting keynote from Arun Ulag, Corporate Vice President, Azure Data.

RTI Forums Carousel3

New forum boards available in Real-Time Intelligence.

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

MayPowerBICarousel1

Power BI Monthly Update - May 2024

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