2017-12-11 12:07:26 +00:00
# Функции для работы с датами и временем
2017-03-12 17:58:51 +00:00
Поддержка часовых поясов
В с е функции по работе с датой и временем, для которых это имеет смысл, могут принимать второй, необязательный аргумент - имя часового пояса. Пример: Asia/Yekaterinburg. В этом случае, они используют не локальный часовой пояс (по умолчанию), а указанный.
2017-10-25 05:27:09 +00:00
```sql
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
```
2017-05-08 05:06:04 +00:00
2017-10-25 05:27:09 +00:00
```text
┌────────────────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 │
└─────────────────────┴────────────┴────────────┴─────────────────────┘
```
2017-05-08 05:06:04 +00:00
2017-03-12 17:58:51 +00:00
Поддерживаются только часовые пояса, отличающиеся от UTC на целое число часов.
2017-12-11 12:07:26 +00:00
## toYear
2017-03-12 17:58:51 +00:00
Переводит дату или дату-с -временем в число типа UInt16, содержащее номер года (AD).
2017-12-11 12:07:26 +00:00
## toMonth
2017-03-12 17:58:51 +00:00
Переводит дату или дату-с -временем в число типа UInt8, содержащее номер месяца (1-12).
2017-12-11 12:07:26 +00:00
## toDayOfMonth
2017-03-12 17:58:51 +00:00
Переводит дату или дату-с -временем в число типа UInt8, содержащее номер дня в месяце (1-31).
2017-12-11 12:07:26 +00:00
## toDayOfWeek
2017-03-12 17:58:51 +00:00
Переводит дату или дату-с -временем в число типа UInt8, содержащее номер дня в неделе (понедельник - 1, воскресенье - 7).
2017-12-11 12:07:26 +00:00
## toHour
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем в число типа UInt8, содержащее номер часа в сутках (0-23).
Функция исходит из допущения, что перевод стрелок вперёд, если осуществляется, то на час, в два часа ночи, а перевод стрелок назад, если осуществляется, то на час, в три часа ночи (что, в общем, не верно - даже в Москве два раза перевод стрелок был осуществлён в другое время).
2017-12-11 12:07:26 +00:00
## toMinute
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем в число типа UInt8, содержащее номер минуты в часе (0-59).
2017-12-11 12:07:26 +00:00
## toSecond
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем в число типа UInt8, содержащее номер секунды в минуте (0-59).
Секунды координации не учитываются.
2017-12-11 12:07:26 +00:00
## toMonday
2017-03-12 17:58:51 +00:00
Округляет дату или дату-с -временем вниз до ближайшего понедельника.
Возвращается дата.
2017-12-11 12:07:26 +00:00
## toStartOfMonth
2017-03-12 17:58:51 +00:00
Округляет дату или дату-с -временем вниз до первого дня месяца.
Возвращается дата.
2017-12-11 12:07:26 +00:00
## toStartOfQuarter
2017-03-12 17:58:51 +00:00
Округляет дату или дату-с -временем вниз до первого дня квартала.
Первый день квартала - это одно из 1 января, 1 апреля, 1 июля, 1 октября.
Возвращается дата.
2017-12-11 12:07:26 +00:00
## toStartOfYear
2017-03-12 17:58:51 +00:00
Округляет дату или дату-с -временем вниз до первого дня года.
Возвращается дата.
2017-12-11 12:07:26 +00:00
## toStartOfMinute
2017-03-12 17:58:51 +00:00
Округляет дату-с -временем вниз до начала минуты.
2017-12-11 12:07:26 +00:00
## toStartOfFiveMinute
2017-03-12 17:58:51 +00:00
Округляет дату-с -временем вниз до начала пятиминутного интервала.
2017-12-22 12:40:00 +00:00
## toStartOfFifteenMinutes
2017-12-22 10:36:39 +00:00
Округляет дату-с -временем вниз до начала пятнадцатиминутного интервала.
2017-03-12 17:58:51 +00:00
Замечание: если вам нужно округлить дату-с -временем до какого-либо другого количества секунд, минут или часов, вы можете перевести её в число с помощью функции toUInt32, затем округлить число с помощью функции intDiv и умножения, а затем перевести обратно, с помощью функции toDateTime.
2017-12-11 12:07:26 +00:00
## toStartOfHour
2017-03-12 17:58:51 +00:00
Округляет дату-с -временем вниз до начала часа.
2017-12-11 12:07:26 +00:00
## toTime
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем на некоторую фиксированную дату, сохраняя при этом время.
2017-12-11 12:07:26 +00:00
## toRelativeYearNum
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем или дату в номер года, начиная с некоторого фиксированного момента в прошлом.
2017-12-11 12:07:26 +00:00
## toRelativeMonthNum
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем или дату в номер месяца, начиная с некоторого фиксированного момента в прошлом.
2017-12-11 12:07:26 +00:00
## toRelativeWeekNum
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем или дату в номер недели, начиная с некоторого фиксированного момента в прошлом.
2017-12-11 12:07:26 +00:00
## toRelativeDayNum
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем или дату в номер дня, начиная с некоторого фиксированного момента в прошлом.
2017-12-11 12:07:26 +00:00
## toRelativeHourNum
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем в номер часа, начиная с некоторого фиксированного момента в прошлом.
2017-12-11 12:07:26 +00:00
## toRelativeMinuteNum
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем в номер минуты, начиная с некоторого фиксированного момента в прошлом.
2017-12-11 12:07:26 +00:00
## toRelativeSecondNum
2017-03-12 17:58:51 +00:00
Переводит дату-с -временем в номер секунды, начиная с некоторого фиксированного момента в прошлом.
2017-12-11 12:07:26 +00:00
## now
2017-10-25 05:27:09 +00:00
2017-03-12 17:58:51 +00:00
Принимает ноль аргументов и возвращает текущее время на один из моментов выполнения запроса.
Функция возвращает константу, даже если запрос выполнялся долго.
2017-12-11 12:07:26 +00:00
## today
2017-03-12 17:58:51 +00:00
Принимает ноль аргументов и возвращает текущую дату на один из моментов выполнения запроса.
Т о же самое, что toDate(now())
2017-12-11 12:07:26 +00:00
## yesterday
2017-03-12 17:58:51 +00:00
Принимает ноль аргументов и возвращает вчерашнюю дату на один из моментов выполнения запроса.
Делает то же самое, что today() - 1.
2017-12-11 12:07:26 +00:00
## timeSlot
2017-03-12 17:58:51 +00:00
Округляет время до получаса.
Эта функция является специфичной для Яндекс.Метрики, так как пол часа - минимальное время, для которого, если соседние по времени хиты одного посетителя на одном счётчике отстоят друг от друга строго более, чем на это время, визит может быть разбит на два визита. Т о есть, кортежи (номер счётчика, идентификатор посетителя, тайм-слот) могут использоваться для поиска хитов, входящий в соответствующий визит.
2017-12-11 12:07:26 +00:00
## timeSlots(StartTime, Duration)
2017-03-12 17:58:51 +00:00
Для интервала времени, начинающегося в StartTime и продолжающегося Duration секунд, возвращает массив моментов времени, состоящий из округлений вниз до получаса точек из этого интервала.
2017-10-25 05:27:09 +00:00
Например, `timeSlots(toDateTime('2012-01-01 12:20:00'), toUInt32(600)) = [toDateTime('2012-01-01 12:00:00'), toDateTime('2012-01-01 12:30:00')]` .
2017-03-12 17:58:51 +00:00
Это нужно для поиска хитов, входящих в соответствующий визит.