Comparison functions
Comparison rules
The comparison functions below return 0 or 1 with type UInt8. Only values within the same group can be
compared (e.g. UInt16 and UInt64) but not across groups (e.g. UInt16 and DateTime).
Comparison of numbers and strings are possible, as is comparison of strings with dates and dates with times.
For tuples and arrays, the comparison is lexicographic meaning that the comparison is made for each corresponding
element of the left side and right side tuple/array.
The following types can be compared:
- numbers and decimals
- strings and fixed strings
- dates
- dates with times
- tuples (lexicographic comparison)
- arrays (lexicographic comparison)
Strings are compared byte-by-byte. This may lead to unexpected results if one of the strings contains UTF-8 encoded multi-byte characters. A string S1 which has another string S2 as prefix is considered longer than S2.
equals
Introduced in: v1.1
Compares two values for equality.
Syntax
Arguments
Returned value
Returns 1 if a is equal to b, otherwise 0 UInt8
Examples
Usage example
greater
Introduced in: v1.1
Compares two values for greater-than relation.
Syntax
Arguments
Returned value
Returns 1 if a is greater than b, otherwise 0 UInt8
Examples
Usage example
greaterOrEquals
Introduced in: v1.1
Compares two values for greater-than-or-equal-to relation.
Syntax
Arguments
Returned value
Returns 1 if a is greater than or equal to b, otherwise 0 UInt8
Examples
Usage example
isDistinctFrom
Introduced in: v25.9
Performs a null-safe "not equals" comparison between two values.
Returns true if the values are distinct (not equal), including when one value is NULL and the other is not.
Returns false if the values are equal, or if both are NULL.
Syntax
Arguments
x— First value to compare. Can be any ClickHouse data type.Anyy— Second value to compare. Can be any ClickHouse data type.Any
Returned value
Returns true if the two values are different, treating NULLs as comparable:
- Returns
trueif x != y. - Returns
trueif exactly one of x or y is NULL. - Returns
falseif x = y, or both x and y are NULL.Bool
Examples
Basic usage with numbers and NULLs
isNotDistinctFrom
Introduced in: v25.9
Performs a null-safe "equals" comparison between two values.
Returns true if the values are equal, including when both are NULL.
Returns false if the values are different, or if exactly one of them is NULL.
Syntax
Arguments
x— First value to compare. Can be any ClickHouse data type.Anyy— Second value to compare. Can be any ClickHouse data type.Any
Returned value
Returns true if the two values are equal, treating NULLs as comparable:
- Returns
trueif x = y. - Returns
trueif both x and y are NULL. - Returns
falseif x != y, or exactly one of x or y is NULL.Bool
Examples
Basic usage with numbers and NULLs
less
Introduced in: v1.1
Compares two values for less-than relation.
Syntax
Arguments
Returned value
Returns 1 if a is less than b, otherwise 0 UInt8
Examples
Usage example
lessOrEquals
Introduced in: v1.1
Compares two values for less-than-or-equal-to relation.
Syntax
Arguments
Returned value
Returns 1 if a is less than or equal to b, otherwise 0 UInt8
Examples
Usage example
notEquals
Introduced in: v1.1
Compares two values for inequality.
Syntax
Arguments
Returned value
Returns 1 if a is not equal to b, otherwise 0. UInt8
Examples
Usage example