ARRAY_INTERSECTION function - Amazon Redshift

Amazon Redshift will no longer support the creation of new Python UDFs starting Patch 198. Existing Python UDFs will continue to function until June 30, 2026. For more information, see the blog post .

ARRAY_INTERSECTION function

Returns a new array containing only the elements that exist in both input arrays. The function is NULL-safe, meaning it treats NULLs are treated as known objects. The order of elements in the result is not guaranteed.

Syntax

ARRAY_INTERSECTION( array1, array2 [, distinct] )

Arguments

array1

A SUPER expression that specifies an array.

array2

A SUPER expression that specifies an array.

distinct

A boolean value that specifies whether to return distinct elements only:

  • distinct = FALSE: Multi-set semantics apply. Duplicate elements are preserved, and the frequency of each element in the result equals the minimum of its frequencies in the two input arrays.
  • distinct = TRUE: Set semantics apply. Only unique elements common to both arrays are returned, with no duplicates.

The default is FALSE.

Return type

The ARRAY_INTERSECTION function returns a SUPER type.

Example

The following examples show the ARRAY_INTERSECTION function.

SELECT ARRAY_INTERSECTION(ARRAY('a','b','c'), ARRAY('b','c','d')); array_intersection -------------------- ["b","c"] (1 row)

Multi-set semantics:

SELECT ARRAY_INTERSECTION(ARRAY('a','b','b'), ARRAY('b','b','b')); array_intersection -------------------- ["b","b"] (1 row)

Set semantics:

SELECT ARRAY_INTERSECTION(ARRAY('a','b','b'), ARRAY('b','b','b'), TRUE); array_intersection -------------------- ["b"] (1 row)

NULLs are treated as known object.

SELECT ARRAY_INTERSECTION(ARRAY('a',NULL), ARRAY('b',NULL)); array_intersection -------------------- [null] (1 row)

See also