uniq
Calculates the approximate number of different values of the argument.
Arguments
The function takes a variable number of parameters. Parameters can be Tuple, Array, Date, DateTime, String, or numeric types.
Returned value
- A UInt64-type number.
Implementation details
Function:
-
Calculates a hash for all parameters in the aggregate, then uses it in calculations.
-
Uses an adaptive sampling algorithm. For the calculation state, the function uses a sample of element hash values up to 65536. This algorithm is very accurate and very efficient on the CPU. When the query contains several of these functions, using
uniqis almost as fast as using other aggregate functions. -
Provides the result deterministically (it does not depend on the query processing order).
We recommend using this function in almost all scenarios.
See Also
uniq
Introduced in: v1.1
Calculates the approximate number of different values of the argument.
The function uses an adaptive sampling algorithm. For the calculation state, the function uses a sample of element hash values up to 65536. This algorithm is very accurate and very efficient on the CPU. When the query contains several of these functions, using uniq is almost as fast as using other aggregate functions.
Implementation details
This function calculates a hash for all parameters in the aggregate, then uses it in calculations.
It uses an adaptive sampling algorithm.
For the calculation state, the function uses a sample of element hash values up to 65536.
This algorithm is very accurate and very efficient on the CPU.
When the query contains several of these functions, using uniq is almost as fast as using other aggregate functions.
We recommend using this function over other variants in almost all scenarios.
Syntax
Arguments
x— The function takes a variable number of parameters.Tuple(T)orArray(T)orDateorDateTimeorStringor(U)Int*orFloat*orDecimal
Returned value
Returns a UInt64-type number representing the approximate number of different values. UInt64
Examples
Example usage
Multiple arguments