Funkcja schema_of_variant
Dotyczy: Databricks SQL
Databricks Runtime 15.3 i nowsze
Zwraca schemat wyrażenia VARIANT
w formacie DDL.
Składnia
schema_of_variant ( variantExpr )
Argumenty
-
variantExpr
: wyrażenieVARIANT
.
Zwraca
Posiadanie definicji schematu STRING
dla variantExpr
.
Typy w schemacie to pochodne typy SQL sformatowane.
Aby uzyskać zagregowany schemat kolekcji VARIANT values
, użyj funkcji agregującej schema_of_variant_agg .
Uwagi
Podczas określania schematu dla ARRAY<elementType>
może być wywnioskowane, że elementType
jest VARIANT
, jeśli w danych występują konflikty typów.
Przykłady
-- Simple example
> SELECT schema_of_variant(parse_json('{"key": 123, "data": [4, 5]}'))
OBJECT<data: ARRAY<BIGINT>, key: BIGINT>
-- Conflicting element types in array
> SELECT schema_of_variant(parse_json('{"data": [{"a":"a"}, 5]}'))
OBJECT<data: ARRAY<VARIANT>>
-- A typed literal
> SELECT schema_of_variant(123.4::VARIANT);
DECIMAL(4,1)
-- Contrasting schema_of_variant() with typeof()
> SELECT typeof(123.4::VARIANT);
VARIANT