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

Функция Таблицы numbers

numbers(N) – Возвращает таблицу с единственной колонкой 'number' (UInt64), содержащей целые числа от 0 до N-1.
numbers(N, M) - Возвращает таблицу с единственной колонкой 'number' (UInt64), содержащей целые числа от N до (N + M - 1).
numbers(N, M, S) - Возвращает таблицу с единственной колонкой 'number' (UInt64), содержащей целые числа от N до (N + M - 1) с шагом S.

Аналогично таблице system.numbers, она может использоваться для тестирования и генерации последовательных значений, при этом numbers(N, M) более эффективен, чем system.numbers.

Следующие запросы эквивалентны:

SELECT * FROM numbers(10);
SELECT * FROM numbers(0, 10);
SELECT * FROM system.numbers LIMIT 10;
SELECT * FROM system.numbers WHERE number BETWEEN 0 AND 9;
SELECT * FROM system.numbers WHERE number IN (0, 1, 2, 3, 4, 5, 6, 7, 8, 9);

И следующие запросы эквивалентны:

SELECT number * 2 FROM numbers(10);
SELECT (number - 10) * 2 FROM numbers(10, 10);
SELECT * FROM numbers(0, 20, 2);

Примеры:

-- Генерация последовательности дат с 2010-01-01 по 2010-12-31
select toDate('2010-01-01') + number as d FROM numbers(365);