> ## Documentation Index
> Fetch the complete documentation index at: https://private-7c7dfe99-fix-nav-issues.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

> Документация по функциям временных окон

# Функции временных окон

export const CloudNotSupportedBadge = () => {
  return <div className="cloudNotSupportedBadge">
            <div className="cloudNotSupportedIcon">
            <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
                <path strokeWidth="1.5" d="M6.33366 12.6666L12.3739 12.6667C13.6593 12.6667 14.7073 11.6187 14.7073 10.3334C14.7073 9.04804 13.6593 8.00003 12.3739 8.00003C12.3739 8.00003 12.3337 7.66659 12.0003 7.33325M10.667 5.33322C8.00033 2.33325 4.45395 4.78537 4.14195 6.68203C2.55728 6.7627 1.29395 8.06203 1.29395 9.6667C1.29395 11.3234 2.66699 12.6666 4.00033 12.6666" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
                <path strokeWidth="1.5" d="M2.66699 14L12.0003 4.66663" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
            </svg>

        </div>
            Not supported in ClickHouse Cloud
        </div>;
};

export const ExperimentalBadge = () => {
  return <div className="experimentalBadge">
            <div className="experimentalIcon">
            <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
                <path strokeWidth="1.25" d="M5.5 2H10.5" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
                <path strokeWidth="1.25" d="M9.50015 2V6.19625L13.4283 12.7425C13.4738 12.8183 13.4985 12.9049 13.4996 12.9934C13.5008 13.0818 13.4785 13.169 13.435 13.246C13.3914 13.323 13.3283 13.3871 13.2519 13.4317C13.1755 13.4764 13.0886 13.4999 13.0002 13.5H3.00015C2.91164 13.5 2.8247 13.4766 2.74822 13.432C2.67174 13.3874 2.60847 13.3233 2.56487 13.2463C2.52126 13.1693 2.49889 13.082 2.50004 12.9935C2.50119 12.905 2.52582 12.8184 2.5714 12.7425L6.50015 6.19625V2" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
                <path strokeWidth="1.25" d="M4.47656 9.56754C5.30344 9.41254 6.47656 9.47942 7.99969 10.25C10.0153 11.2707 11.4216 11.0569 12.2184 10.7282" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
            </svg>
        </div>
            Experimental feature. <u><a href="/docs/beta-and-experimental-features#experimental-features">Learn more.</a></u>
        </div>;
};

Функции временных окон возвращают включённую нижнюю и исключённую верхнюю границу соответствующего окна.
Ниже перечислены функции для работы с [WindowView](/ru/reference/statements/create/view#window-view):

{/*AUTOGENERATED_START*/}

<div id="hop">
  ## hop
</div>

Добавленный в: v21.12.0

Временное hop-окно имеет фиксированную длительность (`window_interval`) и сдвигается на указанный шаг (`hop_interval`). Если `hop_interval` меньше `window_interval`, такие окна перекрываются. Поэтому одна и та же запись может попасть в несколько окон.

Поскольку одна запись может быть отнесена к нескольким hop-окнам, при использовании функции hop без WINDOW VIEW функция возвращает только границу первого окна.

**Синтаксис**

```sql theme={null}
hop(time_attr, hop_interval, window_interval[, timezone])
```

**Аргументы**

* `time_attr` — Дата и время. [`DateTime`](/ru/reference/data-types/datetime)
* `hop_interval` — Положительный интервал hop. [`Interval`](/ru/reference/data-types/int-uint)
* `window_interval` — Положительный интервал window. [`Interval`](/ru/reference/data-types/int-uint)
* `timezone` — Необязательно. Имя часового пояса. [`String`](/ru/reference/data-types/string)

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

Возвращает включённую нижнюю и исключённую верхнюю границы соответствующего hopping-окна. [`Tuple(DateTime, DateTime)`](/ru/reference/data-types/tuple)

**Примеры**

**Hopping window**

```sql title=Query theme={null}
SELECT hop(now(), INTERVAL '1' DAY, INTERVAL '2' DAY)
```

```response title=Response theme={null}
('2024-07-03 00:00:00','2024-07-05 00:00:00')
```

<div id="hopEnd">
  ## hopEnd
</div>

Добавленный в: v22.1.0

Возвращает невключающую верхнюю границу соответствующего hopping-окна.

Поскольку одна запись может относиться к нескольким hop-окнам, функция возвращает только границу первого окна, если функция hop используется без `WINDOW VIEW`.

**Синтаксис**

```sql theme={null}
hopEnd(time_attr, hop_interval, window_interval[, timezone])
```

**Аргументы**

* `time_attr` — Дата и время. [`DateTime`](/ru/reference/data-types/datetime)
* `hop_interval` — Положительный интервал Hop. [`Interval`](/ru/reference/data-types/int-uint)
* `window_interval` — Положительный интервал Window. [`Interval`](/ru/reference/data-types/int-uint)
* `timezone` — Необязательно. Имя часового пояса. [`String`](/ru/reference/data-types/string)

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

Возвращает верхнюю границу соответствующего hopping-окна, не включаемую в интервал. [`DateTime`](/ru/reference/data-types/datetime)

**Примеры**

**Конец hopping-окна**

```sql title=Query theme={null}
SELECT hopEnd(now(), INTERVAL '1' DAY, INTERVAL '2' DAY)
```

```response title=Response theme={null}
2024-07-05 00:00:00
```

<div id="hopStart">
  ## hopStart
</div>

Добавленный в: v22.1.0

Возвращает включённую нижнюю границу соответствующего hopping-окна.

Поскольку одна запись может быть отнесена к нескольким hop-окнам, при использовании функции hop без `WINDOW VIEW` функция возвращает границу только первого окна.

**Синтаксис**

```sql theme={null}
hopStart(time_attr, hop_interval, window_interval[, timezone])
```

**Аргументы**

* `time_attr` — Дата и время. [`DateTime`](/ru/reference/data-types/datetime)
* `hop_interval` — Положительный интервал шага. [`Interval`](/ru/reference/data-types/int-uint)
* `window_interval` — Положительный интервал окна. [`Interval`](/ru/reference/data-types/int-uint)
* `timezone` — Необязательно. Имя часового пояса. [`String`](/ru/reference/data-types/string)

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

Возвращает нижнюю границу соответствующего hopping-окна (включительно). [`DateTime`](/ru/reference/data-types/datetime)

**Примеры**

**Начало hopping-окна**

```sql title=Query theme={null}
SELECT hopStart(now(), INTERVAL '1' DAY, INTERVAL '2' DAY)
```

```response title=Response theme={null}
2024-07-03 00:00:00
```

<div id="tumble">
  ## tumble
</div>

Добавленный в: v21.12.0

Временное неперекрывающееся окно распределяет записи по неперекрывающимся последовательным окнам фиксированной длительности (`interval`).

**Синтаксис**

```sql theme={null}
tumble(time_attr, interval[, timezone])
```

**Аргументы**

* `time_attr` — Дата и время. [`DateTime`](/ru/reference/data-types/datetime)
* `interval` — Интервал окна, заданный типом Interval. [`Interval`](/ru/reference/data-types/int-uint)
* `timezone` — Необязательно. Имя часового пояса. [`String`](/ru/reference/data-types/string)

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

Возвращает нижнюю границу (включительно) и верхнюю границу (исключая) соответствующего неперекрывающегося окна. [`Tuple(DateTime, DateTime)`](/ru/reference/data-types/tuple)

**Примеры**

**Неперекрывающееся окно**

```sql title=Query theme={null}
SELECT tumble(now(), toIntervalDay('1'))
```

```response title=Response theme={null}
('2024-07-04 00:00:00','2024-07-05 00:00:00')
```

<div id="tumbleEnd">
  ## tumbleEnd
</div>

Добавленный в: v22.1.0

Возвращает верхнюю границу соответствующего неперекрывающегося окна, не включая её.

**Синтаксис**

```sql theme={null}
tumbleEnd(time_attr, interval[, timezone])
```

**Аргументы**

* `time_attr` — Дата и время. [`DateTime`](/ru/reference/data-types/datetime)
* `interval` — Интервал окна типа Interval. [`Interval`](/ru/reference/data-types/int-uint)
* `timezone` — Необязательно. Имя часового пояса. [`String`](/ru/reference/data-types/string)

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

Возвращает верхнюю границу соответствующего неперекрывающегося окна, не включая её. [`DateTime`](/ru/reference/data-types/datetime)

**Примеры**

**Конец неперекрывающегося окна**

```sql title=Query theme={null}
SELECT tumbleEnd(now(), toIntervalDay('1'))
```

```response title=Response theme={null}
2024-07-05 00:00:00
```

<div id="tumbleStart">
  ## tumbleStart
</div>

Добавленный в: v22.1.0

Возвращает нижнюю границу соответствующего неперекрывающегося окна (включительно).

**Синтаксис**

```sql theme={null}
tumbleStart(time_attr, interval[, timezone])
```

**Аргументы**

* `time_attr` — Дата и время. [`DateTime`](/ru/reference/data-types/datetime)
* `interval` — Интервал окна типа `Interval`. [`Interval`](/ru/reference/data-types/int-uint)
* `timezone` — Необязательно. Имя часового пояса. [`String`](/ru/reference/data-types/string)

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

Возвращает нижнюю границу (включительно) соответствующего неперекрывающегося окна. [`DateTime`](/ru/reference/data-types/datetime)

**Примеры**

**Начало неперекрывающегося окна**

```sql title=Query theme={null}
SELECT tumbleStart(now(), toIntervalDay('1'))
```

```response title=Response theme={null}
2024-07-04 00:00:00
```

<div id="windowID">
  ## windowID
</div>

Добавленный в: v22.1.0

Возвращает идентификатор соответствующего неперекрывающегося окна или hopping-окна.
Эту функцию можно использовать только с `WINDOW VIEW`.

**Синтаксис**

```sql theme={null}
windowID(time_attr, interval[, timezone])
```

**Аргументы**

* `time_attr` — Дата и время. [`DateTime`](/ru/reference/data-types/datetime)
* `interval` — Интервал окна, тип Interval. [`Interval`](/ru/reference/data-types/int-uint)
* `timezone` — Необязательно. Название часового пояса. [`String`](/ru/reference/data-types/string)

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

Возвращает идентификатор соответствующего окна. [`UInt32`](/ru/reference/data-types/int-uint)

**Примеры**

**Идентификатор окна**

```sql title=Query theme={null}
SELECT windowID(now(), toIntervalDay('1'))
```

```response title=Response theme={null}
```

<div id="related-content">
  ## Материалы по теме
</div>

* [Руководства по использованию временных рядов](/ru/guides/use-cases/real-time-analytics/time-series)
