SELECT knowledge FROM sql_resources WHERE category='bigquery-standard-sql' AND slug='unnest'

UNNEST

Definition

The UNNEST function takes an ARRAY and returns a table with a row for each element in the ARRAY.

unnest_column
1
2
2
5
null

The optional WITH OFFSET clause provides an additional column containing the position of each element in the array (starting at zero) for each row produced by UNNEST.

unnest_columnoffset
10
21
22
53
null4

Practical Info

  • UNNEST requires an ARRAY as an input but can return a table of any structure.
  • Empty arrays and NULL as an input returns an empty table. An array containing NULL values will produce a row of NULL values.

Common Questions

How can I quickly generate a table of values in BigQuery?

You can use UNNEST to quickly create simple tables from arrays. For example:

UNNEST(ARRAY) [WITH OFFSET]
fruitnumber
apples4
pears6
bananas2

How do I join each element in an array column to its corresponding row?

You can do this with a CROSS JOIN. A cross join will take every individual element of your unnested array and join it back to its parent row. This will create multiple rows for each element of your array but you can then filter it down.

fruitbasketfruit_unnest
bananas,apples,orangesbasket 1bananas
bananas,apples,orangesbasket 1apples
bananas,apples,orangesbasket 1oranges
bananas,orangesbasket 2bananas
bananas,orangesbasket 2oranges
bananas,applesbasket 3bananas
bananas,applesbasket 3apples
Loading code...
Loading code...
Loading code...
Loading code...