Перейти к основному содержанию
Перейти к основному содержанию

Interval

Семейство типов данных для представления временных и календарных интервалов. Типы, возвращаемые оператором INTERVAL.

Структура:

  • Интервал в виде беззнакового целого числа.
  • Тип интервала.

Поддерживаемые типы интервалов:

  • NANOSECOND
  • MICROSECOND
  • MILLISECOND
  • SECOND
  • MINUTE
  • HOUR
  • DAY
  • WEEK
  • MONTH
  • QUARTER
  • YEAR

Для каждого типа интервала существует отдельный тип данных. Например, интервал DAY соответствует типу данных IntervalDay:

SELECT toTypeName(INTERVAL 4 DAY)
┌─toTypeName(toIntervalDay(4))─┐
│ IntervalDay                  │
└──────────────────────────────┘

Примечания по использованию

Вы можете использовать значения типа Interval в арифметических операциях над значениями типов Date и DateTime. Например, вы можете прибавить 4 дня к текущему времени:

SELECT now() AS текущая_дата_время, текущая_дата_время + INTERVAL 4 DAY
┌───current_date_time─┬─plus(now(), toIntervalDay(4))─┐
│ 2019-10-23 10:58:45 │           2019-10-27 10:58:45 │
└─────────────────────┴───────────────────────────────┘

Также можно одновременно использовать несколько интервалов:

SELECT now() AS current_date_time, current_date_time + (INTERVAL 4 DAY + INTERVAL 3 HOUR)
┌───current_date_time─┬─plus(current_date_time, plus(toIntervalDay(4), toIntervalHour(3)))─┐
│ 2024-08-08 18:31:39 │                                                2024-08-12 21:31:39 │
└─────────────────────┴────────────────────────────────────────────────────────────────────┘

А чтобы сравнить значения на разных интервалах:

SELECT toIntervalMicrosecond(3600000000) = toIntervalHour(1);
┌─less(toIntervalMicrosecond(179999999), toIntervalMinute(3))─┐
│                                                           1 │
└─────────────────────────────────────────────────────────────┘

См. также

  • INTERVAL — оператор
  • toInterval — функции преобразования типов