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

Табличная функция generate_series

Псевдоним: generateSeries

Синтаксис

Возвращает таблицу с единственным столбцом 'generate_series' (UInt64), содержащим целые числа от start до stop включительно:

generate_series(START, STOP)

Возвращает таблицу с единственным столбцом 'generate_series' (UInt64), содержащим целые числа от start до stop включительно с шагом STEP:

generate_series(START, STOP, STEP)

STEP может быть отрицательным; в этом случае последовательность генерируется в порядке убывания от START к STOP. Если STEP отрицательный и START < STOP, результат будет пустым.

Примеры

Следующие запросы возвращают таблицы с одинаковым содержимым, но разными именами столбцов:

SELECT * FROM numbers(10, 5);
┌─number─┐
│     10 │
│     11 │
│     12 │
│     13 │
│     14 │
└────────┘
SELECT * FROM generate_series(10, 14);
┌─generate_series─┐
│              10 │
│              11 │
│              12 │
│              13 │
│              14 │
└─────────────────┘

Следующие запросы возвращают таблицы с тем же содержимым, но с другими именами столбцов (при этом второй вариант выполняется эффективнее):

SELECT * FROM numbers(10, 11) WHERE number % 3 == (10 % 3);
┌─number─┐
│     10 │
│     13 │
│     16 │
│     19 │
└────────┘
SELECT * FROM generate_series(10, 20, 3);
┌─generate_series─┐
│              10 │
│              13 │
│              16 │
│              19 │
└─────────────────┘

Сгенерируйте убывающую последовательность:

SELECT * FROM generate_series(9, 0, -1);
┌─generate_series─┐
│               9 │
│               8 │
│               7 │
│               6 │
│               5 │
│               4 │
│               3 │
│               2 │
│               1 │
│               0 │
└─────────────────┘