Partilhar via


Tipo TIMESTAMP_NTZ

Aplica-se a: Marque Sim Databricks SQL Marque Sim Databricks Runtime 13.3 LTS e superior

Representa valores que compreendem valores de campos ano, mês, dia, hora, minuto e segundo. Todas as operações são realizadas sem ter em conta qualquer fuso horário.

Esta funcionalidade está em Pré-visualização Pública. Consulte a secção Notas para obter informações sobre funcionalidades não suportadas.

Para usar esse recurso no Delta Lake, você deve habilitar o suporte para a tabela. O suporte a recursos é ativado automaticamente quando você cria uma nova tabela Delta com uma coluna do TIMESTAMP_NTZ tipo. Ele não é ativado automaticamente quando você adiciona uma coluna do TIMESTAMP_NTZ tipo a uma tabela existente. Para habilitar o suporte para TIMESTAMP_NTZ colunas, o suporte para o recurso deve ser explicitamente habilitado para a tabela existente.

Ativar o suporte atualiza seu protocolo de tabela. Consulte Como o Azure Databricks gerencia a compatibilidade de recursos do Delta Lake?. O comando a seguir habilita esse recurso:

ALTER TABLE table_name SET TBLPROPERTIES ('delta.feature.timestampNtz' = 'supported')

Sintaxe

TIMESTAMP_NTZ

Limites

O intervalo de carimbos de data/hora suportados é -290308-12-21 BCE 19:59:06 .+294247-01-10 CE 04:00:54

Literais

TIMESTAMP_NTZ timestampString

timestampString
{ '[+|-]yyyy[...]' |
  '[+|-]yyyy[...]-[m]m' |
  '[+|-]yyyy[...]-[m]m-[d]d' |
  '[+|-]yyyy[...]-[m]m-[d]d ' |
  '[+|-]yyyy[...]-[m]m-[d]d[T][h]h[:]' |
  '[+|-]yyyy[..]-[m]m-[d]d[T][h]h:[m]m[:]' |
  '[+|-]yyyy[...]-[m]m-[d]d[T][h]h:[m]m:[s]s[.]' |
  '[+|-]yyyy[...]-[m]m-[d]d[T][h]h:[m]m:[s]s.[ms][ms][ms][us][us][us]' }
  • + ou -: Um sinal opcional. - indica BCE, + indica CE (padrão).
  • yyyy: Um ano com pelo menos quatro algarismos.
  • [m]m: Um mês de um ou dois dígitos entre 01 e 12.
  • [d]d: Um dia de um ou dois dígitos entre 01 e 31.
  • h[h]: Uma hora de um ou dois dígitos entre 00 e 23.
  • m[m]: Um minuto de um ou dois dígitos entre 00 e 59.
  • s[s]: Um segundo de um ou dois dígitos entre 00 e 59.
  • [ms][ms][ms][us][us][us]: Até 6 dígitos de segundos fracionados.

Se os componentes de mês ou dia não forem especificados, o padrão será 1. Se os componentes hora, minuto ou segundo não forem especificados, o padrão será 0.

Se o literal não representar um carimbo de data/hora adequado, o Azure Databricks gerará um erro.

Notas

  • Atualmente TIMESTAMP_NTZ , o tipo ainda não é suportado em:
    • Fóton
    • Compartilhamento Delta
    • Fontes de dados Databricks usadas no Power BI, Tableau, drivers JDBC/ODBC Databricks ou drivers de código aberto Databricks.
  • TIMESTAMP_NTZ type é suportado em fontes de arquivo, incluindo Delta/Parquet/ORC/AVRO/JSON/CSV. No entanto, há uma limitação na inferência de esquema para arquivos JSON/CSV com colunas TIMESTAMP_NTZ. Para compatibilidade com versões anteriores, o tipo de carimbo de data/hora inferido padrão de ou spark.read.json(...) será o tipo de carimbo de spark.read.csv(...) data/hora em vez de TIMESTAMP_NTZ.

Exemplos

> SELECT TIMESTAMP_NTZ'0000';
  0000-01-01 00:00:00

> SELECT TIMESTAMP_NTZ'2020-12-31';
  2020-12-31 00:00:00

> SELECT TIMESTAMP_NTZ'2021-7-1T8:43:28.123456';
  2021-07-01 08:43:28.123456

> SELECT current_timezone(), CAST(TIMESTAMP '2021-7-1T8:43:28' as TIMESTAMP_NTZ);
  America/Los_Angeles 2021-07-01 08:43:28

> SELECT CAST('1908-03-15 10:1:17' AS TIMESTAMP_NTZ)
  1908-03-15 10:01:17

> SELECT TIMESTAMP_NTZ'+10000';
  +10000-01-01 00:00:00