Поделиться через


тип STRUCT

Область применения: флажок Databricks SQL флажок Databricks Runtime

Значения, которые описывают структуру в виде последовательности полей.

Синтаксис

STRUCT < [fieldName [:] fieldType [NOT NULL] [COMMENT str] [, …] ] >
  • fieldName: идентификатор, обозначающий имя поля. Эти имена не обязаны быть уникальными.
  • fieldType: любой тип данных.
  • NOT NULL: если указано это значение, структура гарантирует отсутствие значений NULL для этого поля.
  • COMMENT str: необязательный строковый литерал, описывающий столбец.

Ограничения

Этот тип поддерживает любое число полей, от 0 и более.

Литералы

Дополнительные сведения о том, как создавать значения литеральных массивов, см. в документации по функции struct и функции named_struct.

Примеры

> 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>>