Typ: STRUCT
Dotyczy: Databricks SQL Databricks Runtime
Reprezentuje wartości ze strukturą opisaną przez sekwencję pól.
Składnia
STRUCT < [fieldName [:] fieldType [NOT NULL] [COLLATE collationName] [COMMENT str] [, …] ] >
fieldName
: identyfikator nazewnictwa pola. Nazwy nie muszą być unikatowe.fieldType
: dowolny typ danych.NOT NULL
: po określeniu struktura gwarantuje, że wartość tego pola nigdy nie jestNULL
.COLLATE
collationName: opcjonalnie określa sortowanie do zastosowania dlafieldType
STRING
.Jeśli nie zostanie określony, porządek sortowania jest
UTF8_BINARY
.COMMENT str
: opcjonalny literał ciągu opisujący pole.
Limity
Typ obsługuje dowolną liczbę pól większej lub równej 0.
Literały
Aby uzyskać szczegółowe informacje na temat tworzenia wartości tablicy literałów, zobacz funkcja struktury i funkcja named_struct.
Przykłady
> SELECT struct('Spark', 5);
{Spark, 5}
> SELECT typeof(named_struct('Field1', 'Spark', 'Field2', 5));
struct<Field1:string,Field2:int>
> SELECT typeof(struct('Spark', 5));
struct<col1:string,col2:int>
> SELECT typeof(CAST(NULL AS STRUCT<Field1:INT NOT NULL COMMENT 'The first field.',Field2:ARRAY<INT>>));
struct<Field1:int,Field2:array<int>>
> SELECT collation(cast(struct(‘hello’)) AS STRUCT<name STRING COLLATE UNICODE_CI>)
UNICODE_CI