Функции для работы с датами и временем 

Поддержка часовых поясов

Все функции по работе с датой и временем, для которых это имеет смысл, могут принимать второй, необязательный аргумент - имя часового пояса. Пример: Asia/Yekaterinburg. В этом случае, они используют не локальный часовой пояс (по умолчанию), а указанный.

SELECT
    toDateTime('2016-06-15 23:00:00') AS time,
    toDate(time) AS date_local,
    toDate(time, 'Asia/Yekaterinburg') AS date_yekat,
    toString(time, 'US/Samoa') AS time_samoa
┌────────────────time─┬─date_local─┬─date_yekat─┬─time_samoa──────────┐
│ 2016-06-15 23:00:00 │ 2016-06-15 │ 2016-06-16 │ 2016-06-15 09:00:00 │
└─────────────────────┴────────────┴────────────┴─────────────────────┘

toTimeZone 

Переводит дату или дату-с-временем в указанный часовой пояс. Часовой пояс (таймзона) это атрибут типов Date/DateTime, внутреннее значение (количество секунд) поля таблицы или колонки результата не изменяется, изменяется тип поля и автоматически его текстовое отображение.

SELECT
    toDateTime('2019-01-01 00:00:00', 'UTC') AS time_utc,
    toTypeName(time_utc) AS type_utc,
    toInt32(time_utc) AS int32utc,
    toTimeZone(time_utc, 'Asia/Yekaterinburg') AS time_yekat,
    toTypeName(time_yekat) AS type_yekat,
    toInt32(time_yekat) AS int32yekat,
    toTimeZone(time_utc, 'US/Samoa') AS time_samoa,
    toTypeName(time_samoa) AS type_samoa,
    toInt32(time_samoa) AS int32samoa
FORMAT Vertical;
Row 1:
──────
time_utc:   2019-01-01 00:00:00
type_utc:   DateTime('UTC')
int32utc:   1546300800
time_yekat: 2019-01-01 05:00:00
type_yekat: DateTime('Asia/Yekaterinburg')
int32yekat: 1546300800
time_samoa: 2018-12-31 13:00:00
type_samoa: DateTime('US/Samoa')
int32samoa: 1546300800

toTimeZone(time_utc, 'Asia/Yekaterinburg') изменяет тип DateTime('UTC') в DateTime('Asia/Yekaterinburg'). Значение (unix-время) 1546300800 остается неизменным, но текстовое отображение (результат функции toString()) меняется time_utc: 2019-01-01 00:00:00 в time_yekat: 2019-01-01 05:00:00.

toYear 

Переводит дату или дату-с-временем в число типа UInt16, содержащее номер года (AD).

Синоним: YEAR.

toQuarter 

Переводит дату или дату-с-временем в число типа UInt8, содержащее номер квартала.

Синоним: QUARTER.

toMonth 

Переводит дату или дату-с-временем в число типа UInt8, содержащее номер месяца (1-12).

Синоним: MONTH.

toDayOfYear 

Переводит дату или дату-с-временем в число типа UInt16, содержащее номер дня года (1-366).

Синоним: DAYOFYEAR.

toDayOfMonth 

Переводит дату или дату-с-временем в число типа UInt8, содержащее номер дня в месяце (1-31).

Синонимы: DAYOFMONTH, DAY.

toDayOfWeek 

Переводит дату или дату-с-временем в число типа UInt8, содержащее номер дня в неделе (понедельник - 1, воскресенье - 7).

Синоним: DAYOFWEEK.

toHour 

Переводит дату-с-временем в число типа UInt8, содержащее номер часа в сутках (0-23).
Функция исходит из допущения, что перевод стрелок вперёд, если осуществляется, то на час, в два часа ночи, а перевод стрелок назад, если осуществляется, то на час, в три часа ночи (что, в общем, не верно - даже в Москве два раза перевод стрелок был осуществлён в другое время).

Синоним: HOUR.

toMinute 

Переводит дату-с-временем в число типа UInt8, содержащее номер минуты в часе (0-59).

Синоним: MINUTE.

toSecond 

Переводит дату-с-временем в число типа UInt8, содержащее номер секунды в минуте (0-59).
Секунды координации не учитываются.

Синоним: SECOND.

toUnixTimestamp 

Переводит дату-с-временем в число типа UInt32 -- Unix Timestamp (https://en.wikipedia.org/wiki/Unix_time).
Для аргумента String, строка конвертируется в дату и время в соответствии с часовым поясом (необязательный второй аргумент, часовой пояс сервера используется по умолчанию).

Синтаксис

toUnixTimestamp(datetime)
toUnixTimestamp(str, [timezone])

Возвращаемое значение

  • Возвращает Unix Timestamp.

Тип: UInt32.

Пример

Запрос:

SELECT toUnixTimestamp('2017-11-05 08:07:47', 'Asia/Tokyo') AS unix_timestamp;

Результат:

┌─unix_timestamp─┐
│     1509836867 │
└────────────────┘

toStartOfYear 

Округляет дату или дату-с-временем вниз до первого дня года.
Возвращается дата.

toStartOfISOYear 

Округляет дату или дату-с-временем вниз до первого дня ISO года. Возвращается дата.
Начало ISO года отличается от начала обычного года, потому что в соответствии с ISO 8601:1988 первая неделя года - это неделя с четырьмя или более днями в этом году.

1 Января 2017 г. - воскресение, т.е. первая ISO неделя 2017 года началась в понедельник 2 января, поэтому 1 января 2017 это 2016 ISO-год, который начался 2016-01-04.

SELECT toStartOfISOYear(toDate('2017-01-01')) AS ISOYear20170101;
┌─ISOYear20170101─┐
│      2016-01-04 │
└─────────────────┘

toStartOfQuarter 

Округляет дату или дату-с-временем вниз до первого дня квартала.
Первый день квартала - это одно из 1 января, 1 апреля, 1 июля, 1 октября.
Возвращается дата.

toStartOfMonth 

Округляет дату или дату-с-временем вниз до первого дня месяца.
Возвращается дата.

toMonday 

Округляет дату или дату-с-временем вниз до ближайшего понедельника.
Возвращается дата.

toStartOfWeek(t[,mode]) 

Округляет дату или дату со временем до ближайшего воскресенья или понедельника в соответствии с mode.
Возвращается дата.
Аргумент mode работает точно так же, как аргумент mode toWeek(). Если аргумент mode опущен, то используется режим 0.

toStartOfDay 

Округляет дату-с-временем вниз до начала дня. Возвращается дата-с-временем.

toStartOfHour 

Округляет дату-с-временем вниз до начала часа.

toStartOfMinute 

Округляет дату-с-временем вниз до начала минуты.

toStartOfSecond 

Отсекает доли секунды.

Синтаксис

toStartOfSecond(value[, timezone])

Аргументы

  • value — дата и время. DateTime64.
  • timezoneчасовой пояс для возвращаемого значения (необязательно). Если параметр не задан, используется часовой пояс параметра value. String.

Возвращаемое значение

  • Входное значение с отсеченными долями секунды.

Тип: DateTime64.

Примеры

Пример без часового пояса:

WITH toDateTime64('2020-01-01 10:20:30.999', 3) AS dt64 SELECT toStartOfSecond(dt64);

Результат:

┌───toStartOfSecond(dt64)─┐
│ 2020-01-01 10:20:30.000 │
└─────────────────────────┘

Пример с часовым поясом:

WITH toDateTime64('2020-01-01 10:20:30.999', 3) AS dt64 SELECT toStartOfSecond(dt64, 'Europe/Moscow');

Результат:

┌─toStartOfSecond(dt64, 'Europe/Moscow')─┐
│                2020-01-01 13:20:30.000 │
└────────────────────────────────────────┘

Смотрите также

  • Часовая зона сервера, конфигурационный параметр timezone.

toStartOfFiveMinute 

Округляет дату-с-временем вниз до начала пятиминутного интервала.

toStartOfTenMinutes 

Округляет дату-с-временем вниз до начала десятиминутного интервала.

toStartOfFifteenMinutes 

Округляет дату-с-временем вниз до начала пятнадцатиминутного интервала.

toStartOfInterval(time_or_data, INTERVAL x unit [, time_zone]) 

Обобщение остальных функций toStartOf*. Например,
toStartOfInterval(t, INTERVAL 1 year) возвращает то же самое, что и toStartOfYear(t),
toStartOfInterval(t, INTERVAL 1 month) возвращает то же самое, что и toStartOfMonth(t),
toStartOfInterval(t, INTERVAL 1 day) возвращает то же самое, что и toStartOfDay(t),
toStartOfInterval(t, INTERVAL 15 minute) возвращает то же самое, что и toStartOfFifteenMinutes(t), и т.п.

toTime 

Переводит дату-с-временем на некоторую фиксированную дату, сохраняя при этом время.

toRelativeYearNum 

Переводит дату-с-временем или дату в номер года, начиная с некоторого фиксированного момента в прошлом.

toRelativeQuarterNum 

Переводит дату-с-временем или дату в номер квартала, начиная с некоторого фиксированного момента в прошлом.

toRelativeMonthNum 

Переводит дату-с-временем или дату в номер месяца, начиная с некоторого фиксированного момента в прошлом.

toRelativeWeekNum 

Переводит дату-с-временем или дату в номер недели, начиная с некоторого фиксированного момента в прошлом.

toRelativeDayNum 

Переводит дату-с-временем или дату в номер дня, начиная с некоторого фиксированного момента в прошлом.

toRelativeHourNum 

Переводит дату-с-временем в номер часа, начиная с некоторого фиксированного момента в прошлом.

toRelativeMinuteNum 

Переводит дату-с-временем в номер минуты, начиная с некоторого фиксированного момента в прошлом.

toRelativeSecondNum 

Переводит дату-с-временем в номер секунды, начиная с некоторого фиксированного момента в прошлом.

toISOYear 

Переводит дату-с-временем или дату в число типа UInt16, содержащее номер ISO года. ISO год отличается от обычного года, потому что в соответствии с ISO 8601:1988 ISO год начинается необязательно первого января.

Пример

Запрос:

SELECT
    toDate('2017-01-01') AS date,
    toYear(date),
    toISOYear(date)

Результат:

┌───────date─┬─toYear(toDate('2017-01-01'))─┬─toISOYear(toDate('2017-01-01'))─┐
│ 2017-01-01 │                         2017 │                            2016 │
└────────────┴──────────────────────────────┴─────────────────────────────────┘

toISOWeek 

Переводит дату-с-временем или дату в число типа UInt8, содержащее номер ISO недели.
Начало ISO года отличается от начала обычного года, потому что в соответствии с ISO 8601:1988 первая неделя года - это неделя с четырьмя или более днями в этом году.

1 Января 2017 г. - воскресение, т.е. первая ISO неделя 2017 года началась в понедельник 2 января, поэтому 1 января 2017 это последняя неделя 2016 года.

Пример

Запрос:

SELECT
    toISOWeek(toDate('2017-01-01')) AS ISOWeek20170101,
    toISOWeek(toDate('2017-01-02')) AS ISOWeek20170102

Результат:

┌─ISOWeek20170101─┬─ISOWeek20170102─┐
│              52 │               1 │
└─────────────────┴─────────────────┘

toWeek(date[, mode][, timezone]) 

Переводит дату-с-временем или дату в число UInt8, содержащее номер недели. Второй аргументам mode задает режим, начинается ли неделя с воскресенья или с понедельника и должно ли возвращаемое значение находиться в диапазоне от 0 до 53 или от 1 до 53. Если аргумент mode опущен, то используется режим 0.

toISOWeek() эквивалентно toWeek(date,3).

Описание режимов (mode):

Mode Первый день недели Диапазон Неделя 1 это первая неделя …
0 Воскресенье 0-53 с воскресеньем в этом году
1 Понедельник 0-53 с 4-мя или более днями в этом году
2 Воскресенье 1-53 с воскресеньем в этом году
3 Понедельник 1-53 с 4-мя или более днями в этом году
4 Воскресенье 0-53 с 4-мя или более днями в этом году
5 Понедельник 0-53 с понедельником в этом году
6 Воскресенье 1-53 с 4-мя или более днями в этом году
7 Понедельник 1-53 с понедельником в этом году
8 Воскресенье 1-53 содержащая 1 января
9 Понедельник 1-53 содержащая 1 января

Для режимов со значением «с 4 или более днями в этом году» недели нумеруются в соответствии с ISO 8601:1988:

  • Если неделя, содержащая 1 января, имеет 4 или более дней в новом году, это неделя 1.

  • В противном случае это последняя неделя предыдущего года, а следующая неделя - неделя 1.

Для режимов со значением «содержит 1 января», неделя 1 – это неделя содержащая 1 января. Не имеет значения, сколько дней в новом году содержала неделя, даже если она содержала только один день.

Пример

Запрос:

SELECT toDate('2016-12-27') AS date, toWeek(date) AS week0, toWeek(date,1) AS week1, toWeek(date,9) AS week9;

Результат:

┌───────date─┬─week0─┬─week1─┬─week9─┐
│ 2016-12-27 │    52 │    52 │     1 │
└────────────┴───────┴───────┴───────┘

toYearWeek(date[,mode]) 

Возвращает год и неделю для даты. Год в результате может отличаться от года в аргументе даты для первой и последней недели года.

Аргумент mode работает точно так же, как аргумент mode toWeek(). Если mode не задан, используется режим 0.

toISOYear() эквивалентно intDiv(toYearWeek(date,3),100).

Пример

Запрос:

SELECT toDate('2016-12-27') AS date, toYearWeek(date) AS yearWeek0, toYearWeek(date,1) AS yearWeek1, toYearWeek(date,9) AS yearWeek9;

Результат:

┌───────date─┬─yearWeek0─┬─yearWeek1─┬─yearWeek9─┐
│ 2016-12-27 │    201652 │    201652 │    201701 │
└────────────┴───────────┴───────────┴───────────┘

date_trunc 

Отсекает от даты и времени части, меньшие чем указанная часть.

Синтаксис

date_trunc(unit, value[, timezone])

Синоним: dateTrunc.

Аргументы

  • unit — единица измерения времени, в которой задана отсекаемая часть. String Literal.
    Возможные значения:

    • second
    • minute
    • hour
    • day
    • week
    • month
    • quarter
    • year
  • value — дата и время. DateTime или DateTime64.

  • timezoneчасовой пояс для возвращаемого значения (необязательно). Если параметр не задан, используется часовой пояс параметра value. String

Возвращаемое значение

  • Дата и время, отсеченные до указанной части.

Тип: Datetime.

Примеры

Запрос без указания часового пояса:

SELECT now(), date_trunc('hour', now());

Результат:

┌───────────────now()─┬─date_trunc('hour', now())─┐
│ 2020-09-28 10:40:45 │       2020-09-28 10:00:00 │
└─────────────────────┴───────────────────────────┘

Запрос с указанием часового пояса:

SELECT now(), date_trunc('hour', now(), 'Europe/Moscow');

Результат:

┌───────────────now()─┬─date_trunc('hour', now(), 'Europe/Moscow')─┐
│ 2020-09-28 10:46:26 │                        2020-09-28 13:00:00 │
└─────────────────────┴────────────────────────────────────────────┘

Смотрите также

date_add 

Добавляет интервал времени или даты к указанной дате или дате со временем.

Синтаксис

date_add(unit, value, date)

Синонимы: dateAdd, DATE_ADD.

Аргументы

  • unit — единица измерения времени, в которой задан интервал для добавления. String.
    Возможные значения:

    • second
    • minute
    • hour
    • day
    • week
    • month
    • quarter
    • year
  • value — значение интервала для добавления. Int.

  • date — дата или дата со временем, к которой добавляется value. Date или DateTime.

Возвращаемое значение

Дата или дата со временем, полученная в результате добавления value, выраженного в unit, к date.

Тип: Date или DateTime.

Пример

Запрос:

SELECT date_add(YEAR, 3, toDate('2018-01-01'));

Результат:

┌─plus(toDate('2018-01-01'), toIntervalYear(3))─┐
│                                    2021-01-01 │
└───────────────────────────────────────────────┘

date_diff 

Вычисляет разницу между двумя значениями дат или дат со временем.

Синтаксис

date_diff('unit', startdate, enddate, [timezone])

Синонимы: dateDiff, DATE_DIFF.

Аргументы

  • unit — единица измерения времени, в которой будет выражено возвращаемое значение функции. String.
    Возможные значения:

    • second
    • minute
    • hour
    • day
    • week
    • month
    • quarter
    • year
  • startdate — первая дата или дата со временем, которая вычитается из enddate. Date или DateTime.

  • enddate — вторая дата или дата со временем, из которой вычитается startdate. Date или DateTime.

  • timezoneчасовой пояс (необязательно). Если этот аргумент указан, то он применяется как для startdate, так и для enddate. Если этот аргумент не указан, то используются часовые пояса аргументов startdate и enddate. Если часовые пояса аргументов startdate и enddate не совпадают, то результат не определен. String.

Возвращаемое значение

Разница между enddate и startdate, выраженная в unit.

Тип: Int.

Пример

Запрос:

SELECT dateDiff('hour', toDateTime('2018-01-01 22:00:00'), toDateTime('2018-01-02 23:00:00'));

Результат:

┌─dateDiff('hour', toDateTime('2018-01-01 22:00:00'), toDateTime('2018-01-02 23:00:00'))─┐
│                                                                                     25 │
└────────────────────────────────────────────────────────────────────────────────────────┘

date_sub 

Вычитает интервал времени или даты из указанной даты или даты со временем.

Синтаксис

date_sub(unit, value, date)

Синонимы: dateSub, DATE_SUB.

Аргументы

  • unit — единица измерения времени, в которой задан интервал для вычитания. String.
    Возможные значения:

    • second
    • minute
    • hour
    • day
    • week
    • month
    • quarter
    • year
  • value — значение интервала для вычитания. Int.

  • date — дата или дата со временем, из которой вычитается value. Date или DateTime.

Возвращаемое значение

Дата или дата со временем, полученная в результате вычитания value, выраженного в unit, из date.

Тип: Date или DateTime.

Пример

Запрос:

SELECT date_sub(YEAR, 3, toDate('2018-01-01'));

Результат:

┌─minus(toDate('2018-01-01'), toIntervalYear(3))─┐
│                                     2015-01-01 │
└────────────────────────────────────────────────┘

timestamp_add 

Добавляет интервал времени к указанной дате или дате со временем.

Синтаксис

timestamp_add(date, INTERVAL value unit)

Синонимы: timeStampAdd, TIMESTAMP_ADD.

Аргументы

  • date — дата или дата со временем. Date или DateTime.
  • value — значение интервала для добавления. Int.
  • unit — единица измерения времени, в которой задан интервал для добавления. String.
    Возможные значения:

    • second
    • minute
    • hour
    • day
    • week
    • month
    • quarter
    • year

Возвращаемое значение

Дата или дата со временем, полученная в результате добавления value, выраженного в unit, к date.

Тип: Date или DateTime.

Пример

Запрос:

select timestamp_add(toDate('2018-01-01'), INTERVAL 3 MONTH);

Результат:

┌─plus(toDate('2018-01-01'), toIntervalMonth(3))─┐
│                                     2018-04-01 │
└────────────────────────────────────────────────┘

timestamp_sub 

Вычитает интервал времени из указанной даты или даты со временем.

Синтакис

timestamp_sub(unit, value, date)

Синонимы: timeStampSub, TIMESTAMP_SUB.

Аргументы

  • unit — единица измерения времени, в которой задан интервал для вычитания. String.
    Возможные значения:

    • second
    • minute
    • hour
    • day
    • week
    • month
    • quarter
    • year
  • value — значение интервала для вычитания. Int.

  • date — дата или дата со временем. Date или DateTime.

Возвращаемое значение

Дата или дата со временем, полученная в результате вычитания value, выраженного в unit, из date.

Тип: Date или DateTime.

Пример

Запрос:

select timestamp_sub(MONTH, 5, toDateTime('2018-12-18 01:02:03'));

Результат:

┌─minus(toDateTime('2018-12-18 01:02:03'), toIntervalMonth(5))─┐
│                                          2018-07-18 01:02:03 │
└──────────────────────────────────────────────────────────────┘

now 

Возвращает текущую дату и время.

Синтаксис

now([timezone])

Параметры

Возвращаемое значение

  • Текущие дата и время.

Тип: Datetime.

Пример

Запрос без указания часового пояса:

SELECT now();

Результат:

┌───────────────now()─┐
│ 2020-10-17 07:42:09 │
└─────────────────────┘

Запрос с указанием часового пояса:

SELECT now('Europe/Moscow');

Результат:

┌─now('Europe/Moscow')─┐
│  2020-10-17 10:42:23 │
└──────────────────────┘

today 

Возвращает текущую дату на момент выполнения запроса. Функция не требует аргументов.
То же самое, что toDate(now())

yesterday 

Возвращает вчерашнюю дату на момент выполнения запроса.
Делает то же самое, что today() - 1. Функция не требует аргументов.

timeSlot 

Округляет время до получаса.
Эта функция является специфичной для Яндекс.Метрики, так как пол часа - минимальное время, для которого, если соседние по времени хиты одного посетителя на одном счётчике отстоят друг от друга строго более, чем на это время, визит может быть разбит на два визита. То есть, кортежи (номер счётчика, идентификатор посетителя, тайм-слот) могут использоваться для поиска хитов, входящий в соответствующий визит.

timeSlots(StartTime, Duration,[, Size]) 

Для интервала времени, начинающегося в ‘StartTime’ и продолжающегося ‘Duration’ секунд, возвращает массив моментов времени, состоящий из округлений вниз до ‘Size’ точек в секундах из этого интервала. ‘Size’ - необязательный параметр, константный UInt32, по умолчанию равен 1800.

Например, timeSlots(toDateTime('2012-01-01 12:20:00'), toUInt32(600)) = [toDateTime('2012-01-01 12:00:00'), toDateTime('2012-01-01 12:30:00')].
Это нужно для поиска хитов, входящих в соответствующий визит.

toYYYYMM 

Переводит дату или дату со временем в число типа UInt32, содержащее номер года и месяца (YYYY * 100 + MM).

toYYYYMMDD 

Переводит дату или дату со временем в число типа UInt32, содержащее номер года, месяца и дня (YYYY * 10000 + MM * 100 + DD).

toYYYYMMDDhhmmss 

Переводит дату или дату со временем в число типа UInt64 содержащее номер года, месяца, дня и время (YYYY * 10000000000 + MM * 100000000 + DD * 1000000 + hh * 10000 + mm * 100 + ss).

formatDateTime 

Функция преобразует дату-и-время в строку по заданному шаблону. Важно: шаблон — константное выражение, поэтому использовать разные шаблоны в одной колонке не получится.

Синтаксис

formatDateTime(Time, Format\[, Timezone\])

Возвращаемое значение

Возвращает значение времени и даты в определенном вами формате.

Поля подстановки

Используйте поля подстановки для того, чтобы определить шаблон для выводимой строки. В колонке «Пример» результат работы функции для времени 2018-01-02 22:33:44.

Поле Описание Пример
%C номер года, поделённый на 100 (00-99) 20
%d день месяца, с ведущим нулём (01-31) 02
%D короткая запись %m/%d/%y 01/02/18
%e день месяца, с ведущим пробелом ( 1-31)   2
%F короткая запись %Y-%m-%d 2018-01-02
%G четырехзначный формат вывода ISO-года, который основывается на особом подсчете номера недели согласно стандарту ISO 8601, обычно используется вместе с %V 2018
%g двузначный формат вывода года по стандарту ISO 8601 18
%H час в 24-часовом формате (00-23) 22
%I час в 12-часовом формате (01-12) 10
%j номер дня в году, с ведущими нулями (001-366) 002
%m месяц, с ведущим нулём (01-12) 01
%M минуты, с ведущим нулём (00-59) 33
%n символ переноса строки (‘’)
%p обозначения AM или PM PM
%Q квартал (1-4) 1
%R короткая запись %H:%M 22:33
%S секунды, с ведущими нулями (00-59) 44
%t символ табуляции (’)
%T формат времени ISO 8601, одинаковый с %H:%M:%S 22:33:44
%u номер дня недели согласно ISO 8601, понедельник - 1, воскресенье - 7 2
%V номер недели согласно ISO 8601 (01-53) 01
%w номер дня недели, начиная с воскресенья (0-6) 2
%y год, последние 2 цифры (00-99) 18
%Y год, 4 цифры 2018
%% символ % %

Пример

Запрос:

SELECT formatDateTime(toDate('2010-01-04'), '%g');

Результат:

┌─formatDateTime(toDate('2010-01-04'), '%g')─┐
│ 10                                         │
└────────────────────────────────────────────┘

FROM_UNIXTIME 

Функция преобразует Unix timestamp в календарную дату и время.

Примеры

Если указан только один аргумент типа Integer, то функция действует так же, как toDateTime, и возвращает тип DateTime.

Запрос:

SELECT FROM_UNIXTIME(423543535);

Результат:

┌─FROM_UNIXTIME(423543535)─┐
│      1983-06-04 10:58:55 │
└──────────────────────────┘

В случае, когда есть два аргумента: первый типа Integer или DateTime, а второй является строкой постоянного формата — функция работает также, как formatDateTime, и возвращает значение типа String.

Запрос:

SELECT FROM_UNIXTIME(1234334543, '%Y-%m-%d %R:%S') AS DateTime;

Результат:

┌─DateTime────────────┐
│ 2009-02-11 14:42:23 │
└─────────────────────┘

Rating: 2.7 - 62 votes

Was this content helpful?
★★★☆☆