OR DAX Function (Logical)

Returns TRUE if any of the arguments are TRUE, and returns FALSE if all arguments are FALSE.

Syntax

OR ( <Logical1>, <Logical2> )
Parameter Attributes Description
Logical1

The logical values you want to test.

Logical2

The logical values you want to test.

Return values

Scalar A single boolean value.

The value is TRUE if any of the two arguments is TRUE; the value is FALSE if both the arguments are FALSE.

Remarks

The OR function accepts only two arguments. Consider using the operator || to avoid multiple nested calls in case there are three or more conditions to evaluate in a logical OR.

» 2 related articles
» 2 related functions

Examples

--  TRUE and FALSE are the two constant values of True and False (1, 0 )
--  AND performs the logical AND between two conditions
--  OR performs the logical OR between two conditions
--  NOT performs logical negation
EVALUATE
    {
        ( "FALSE", FALSE ),
        ( "FALSE()", FALSE() ),
        ( "TRUE", TRUE ),
        ( "TRUE()", TRUE() ),
        ( "AND ( TRUE, FALSE )", AND ( TRUE, FALSE ) ),
        ( "OR ( TRUE, FALSE )", OR ( TRUE, FALSE ) ),
        ( "NOT ( TRUE )", NOT ( TRUE ) ),
        ( "NOT ( FALSE )", NOT ( FALSE ) )        
    }
Value1 Value2
FALSE false
FALSE() false
TRUE true
TRUE() true
AND ( TRUE, FALSE ) false
OR ( TRUE, FALSE ) true
NOT ( TRUE ) false
NOT ( FALSE ) true
--  The AND function can be replaced with the && operator
--  The OR function can be replaced with the || operator
EVALUATE
    {
        ( "AND ( TRUE, FALSE )", AND ( TRUE, FALSE ) ),
        ( "TRUE && FALSE", TRUE && FALSE ),
        ( "OR ( TRUE, FALSE )", OR ( TRUE, FALSE ) ),
        ( "TRUE || FALSE", TRUE || FALSE )
    }
Value1 Value2
AND ( TRUE, FALSE ) false
TRUE && FALSE false
OR ( TRUE, FALSE ) true
TRUE || FALSE true
--  Operators are more convenient when you need to combine
--  more than two conditions.
EVALUATE
    VAR A = TRUE
    VAR B = FALSE
    VAR C = TRUE
RETURN
    {
        ( "Using OR", OR ( A, OR ( B, C ) ) ),
        ( "Using ||",  A|| B || C )
    }
Value1 Value2
Using OR true
Using || true

Related articles

Learn more about OR in the following articles:

Related functions

Other related functions are:

Last update: Oct 22, 2025   » Contribute   » Show contributors

Contributors: Alberto Ferrari, Marco Russo

Microsoft documentation: https://docs.microsoft.com/en-us/dax/or-function-dax

2018-2025 © SQLBI. All rights are reserved. Information coming from Microsoft documentation is property of Microsoft Corp. » Contact us   » Privacy Policy & Cookies

Context Transition

This function performs a Context Transition if called in a Row Context. Click to read more.

Row Context

This expression is executed in a Row Context. Click to read more.

Passed by Expression

This parameter is passed by expression and can be evaluated multiple times in different evaluation contexts.

Iterator

Not recommended

The use of this function is not recommended. See Remarks and Related functions for alternatives.

Not recommended

The use of this parameter is not recommended.

Deprecated

This function is deprecated. Jump to the Alternatives section to see the function to use.

Volatile

A volatile function may return a different result every time you call it, even if you provide the same arguments. Click to read more.

Deprecated

This parameter is deprecated and its use is not recommended.

DirectQuery compatibility

Limitations are placed on DAX expressions allowed in measures and calculated columns.
The state below shows the DirectQuery compatibility of the DAX function.

Contribute

Want to improve the content of OR? Did you find any issue?
Please, report it us! All submissions will be evaluated for possible updates of the content.


This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.