Função date_diff
Aplica-se a: Databricks SQL Databricks Runtime 13.3 LTS e superior
Devolve a diferença entre dois carimbos de data/hora medidos em unit
s. date_diff
(timestamp) é um sinônimo de timestampdiff função.
Sintaxe
date_diff(unit, start, end)
unit
{ MICROSECOND |
MILLISECOND |
SECOND |
MINUTE |
HOUR |
DAY |
WEEK |
MONTH |
QUARTER |
YEAR }
Argumentos
unit
: Uma unidade de medida.start
: Uma expressão inicial de carimbo de data/hora.end
: Uma expressão TIMESTAMP final.
Devoluções
A BIGINT
.
Se start
for maior que end
o resultado é negativo.
A função conta unidades inteiras decorridas com base em UTC
um DAY
ser 86400 segundos.
Considera-se decorrido um mês quando o mês civil tiver aumentado e o dia e a hora do calendário forem iguais ou superiores ao início. Seguem-se semanas, trimestres e anos.
Exemplos
-- One second shy of a month elapsed
> SELECT date_diff(MONTH, TIMESTAMP'2021-02-28 12:00:00', TIMESTAMP'2021-03-28 11:59:59');
0
-- One month has passed even though its' not end of the month yet because day and time line up.
> SELECT date_diff(MONTH, TIMESTAMP'2021-02-28 12:00:00', TIMESTAMP'2021-03-28 12:00:00');
1
-- Start is greater than the end
> SELECT date_diff(YEAR, DATE'2021-01-01', DATE'1900-03-28');
-120