Compartilhar via


TipoSTRUCT

Aplica-se a:marca de seleção positiva SQL do Databricks marca de seleção positiva Runtime do Databricks

Representa valores com a estrutura descrita por uma sequência de campos.

Sintaxe

STRUCT < [fieldName [:] fieldType [NOT NULL] [COLLATE collationName] [COMMENT str] [, …] ] >
  • fieldName: um identificador que nomeia o campo. Os nomes não precisam ser exclusivos.

  • fieldType: qualquer tipo de dados.

  • NOT NULL: Quando especificado, o struct garante que o valor deste campo nunca seja NULL.

  • COLLATE collationName: opcionalmente, isso define a ordenação a ser usada para um fieldType de STRING.

    Se não for especificado, a ordenação será herdada do contexto no qual a STRUCT opção é definida:

    • Dentro de um CREATE ou ALTER de um TABLE, VIEW, ou FUNCTION, a ordenação padrão corresponde à ordenação padrão daquele TABLE, VIEW, ou FUNCTION.
    • Dentro do contexto de uma UPDATE instrução de nível superior, DELETE, INSERT, MERGE ou instrução de consulta, a ordenação padrão é UTF8_BINARY.
  • COMMENT str: um literal de CADEIA DE CARACTERES opcional que descreve o alias da coluna.

Limites

O tipo dá suporte a qualquer número de campos maior ou igual a 0.

Literais

Consulte struct a função e named_struct a função para obter detalhes sobre como produzir valores de matriz literal.

Exemplos

> 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>).name);
 SYSTEM.BUILTIN.UNICODE_CI