ARRAY_UNION
Function
ARRAY_UNION returns the union of multiple arrays, i.e., merges all elements from the arrays, removes duplicates, and returns a new array.
Syntax
ARRAY_UNION(arr1, arr2, ..., arrN)
Parameters
- arr1, arr2, ..., arrN: Any number of array inputs, all of type- ARRAY<T>.- The element type Tof all arrays must be the same, or implicitly convertible to a unified type.
- The element type Tcan be numeric, string, date/time, or IP type.
 
- The element type 
Return Value
- Returns a new array of type ARRAY<T>containing all unique elements from the input arrays (duplicates removed).- If any input parameter is NULL, returnsNULL(see example).
 
- If any input parameter is 
Usage Notes
- Duplicate removal is based on equality comparison (=operator).
- Only one NULLwill be kept in the result array (see example).
- If the input array itself contains multiple identical elements, only one will be kept (see example).
- The order of elements in the result array is not guaranteed.
Examples
- 
Simple example SELECT ARRAY_UNION(ARRAY('hello', 'world'), ARRAY('hello', 'world'));
 +---------------------------------------------------------------+
 | ARRAY_UNION(ARRAY('hello', 'world'), ARRAY('hello', 'world')) |
 +---------------------------------------------------------------+
 | ["world", "hello"] |
 +---------------------------------------------------------------+
 SELECT ARRAY_UNION(ARRAY(1, 2, 3), ARRAY(3, 5, 6));
 +---------------------------------------------+
 | ARRAY_UNION(ARRAY(1, 2, 3), ARRAY(3, 5, 6)) |
 +---------------------------------------------+
 | [1, 5, 2, 6, 3] |
 +---------------------------------------------+
- 
If any input array is NULL, returnsNULLSELECT ARRAY_UNION(ARRAY('hello', 'world'), ARRAY('hello', 'world'), NULL);
 +---------------------------------------------------------------------+
 | ARRAY_UNION(ARRAY('hello', 'world'), ARRAY('hello', 'world'), NULL) |
 +---------------------------------------------------------------------+
 | NULL |
 +---------------------------------------------------------------------+
- 
If input arrays contain NULL, the output array will contain only oneNULLSELECT ARRAY_UNION(ARRAY('hello', 'world'), ARRAY('hello', NULL));
 +------------------------------------------------------------+
 | ARRAY_UNION(ARRAY('hello', 'world'), ARRAY('hello', NULL)) |
 +------------------------------------------------------------+
 | [null, "world", "hello"] |
 +------------------------------------------------------------+
 SELECT ARRAY_UNION(ARRAY(NULL, 'world'), ARRAY('hello', NULL));
 +---------------------------------------------------------+
 | ARRAY_UNION(ARRAY(NULL, 'world'), ARRAY('hello', NULL)) |
 +---------------------------------------------------------+
 | [null, "world", "hello"] |
 +---------------------------------------------------------+
- 
If an array contains duplicate elements, only one will be returned SELECT ARRAY_UNION(ARRAY('hello', 'world', 'hello'), ARRAY('hello', NULL));
 +------------------------------------------------------------+
 | ARRAY_UNION(ARRAY('hello', 'world'), ARRAY('hello', NULL)) |
 +------------------------------------------------------------+
 | [null, "world", "hello"] |
 +------------------------------------------------------------+