inline
funkcja generatora wartości tabeli
Dotyczy: Databricks SQL
Databricks Runtime
Eksploduje tablicę struktur w tabeli.
W usługach Databricks SQL i Databricks Runtime 16.1 i nowszych ta funkcja obsługuje wywoływanie parametrów.
Składnia
inline(input)
Argumenty
-
input
: wyrażenieARRAY<STRUCT>
.
Zwraca
Zestaw wierszy składający się z pól w elementach struktury tablicy input
.
Kolumny generowane przez inline
są nazwami pól.
Jeśli input
nie są NULL
generowane żadne wiersze.
Dotyczy:
Databricks Runtime 12.1 i starsze:
inline
można umieścić tylko na liścieSELECT
jako początek wyrażenia lub po LATERAL VIEW. Podczas umieszczania funkcji na liścieSELECT
nie może istnieć żadna inna funkcja generatora na tej samej liścieSELECT
, w przeciwnym razie zostaje zgłoszony błąd UNSUPPORTED_GENERATOR.MULTI_GENERATOR.Dotyczy:
Databricks SQL
Databricks Runtime 12.2 LTS i nowsze:
Odwołanie z klauzuli LATERAL VIEW lub z listy
SELECT
jest przestarzałe. Zamiast tego należy wywołaćinline
jako table_reference.
Przykłady
Dotyczy: Databricks Runtime 12.1 i starsze:
> SELECT inline(array(struct(1, 'a'), struct(2, 'b'))), 'Spark SQL';
1 a Spark SQL
2 b Spark SQL
> SELECT inline(array(struct(1, 'a'), struct(1, 'b'))),
inline(array(struct('c', 1.0), struct('d', 2.0))),
'Spark SQL';
1 a Spark SQL
2 b Spark SQL
Error: UNSUPPORTED_GENERATOR.MULTI_GENERATOR
Dotyczy: Databricks SQL
Databricks Runtime 12.2 LTS i nowsze:
> SELECT i.*, 'Spark SQL'
FROM inline(array(struct(1, 'a'), struct(2, 'b'))) AS i;
1 a Spark SQL
2 b Spark SQL
> SELECT i1.*, i2.*, 'Spark SQL'
FROM inline(array(struct(1, 'a'), struct(1, 'b'))) AS i1,
inline(array(struct('c', 1.0), struct('d', 2.0))) AS i2;
1 a c 1.0 Spark SQL
1 b c 1.0 Spark SQL
1 a d 2.0 Spark SQL
1 b d 2.0 Spark SQL