Compartilhar via


TipoTIMESTAMP

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

Representa valores de campos de ano, mês, dia, hora, minuto e segundo, com o fuso horário local da sessão. O valor do carimbo de data/hora representa um ponto absoluto no tempo.

Sintaxe

TIMESTAMP

Limites

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

Literais

TIMESTAMP 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][zoneId]' }
  • + ou -: um sinal opcional. - indica a.C, + indica d.C (padrão).
  • yyyy: um ano com no mínimo quatro dígitos.
  • [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 frações de segundo.

zoneId:

  • Z - Fuso horário Zulu UTC+0
  • +|-[h]h:[m]m
  • ID com um dos prefixos UTC+, UTC-, GMT+, GMT-, UT+ ou UT- e um sufixo nos formatos:
    • +|-h[h]
    • +|-hh[:]mm
    • +|-hh:mm:ss
    • +|-hhmmss
  • IDs de fuso baseadas em região no formato <area>/<city>, por exemplo, Europe/Paris.

Se os componentes 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 nenhum zoneId for especificado, o padrão será o fuso horário da sessão,

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

Observações

Os carimbos de data/hora com o fuso horário local são normalizados e persistentes em UTC. Sempre que o valor ou uma parte dele é extraído, o fuso horário da sessão local é aplicado.

Exemplos

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

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

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

> SELECT current_timezone(), TIMESTAMP'2021-7-1T8:43:28UTC+3';
  America/Los_Angeles 2021-06-30 22:43:28

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

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