数字
numbers(N)
- 返回一个包含从 0 到 N-1 的整数的单个 'number' 列(UInt64)的表。numbers(N, M)
- 返回一个包含从 N 到 (N + M - 1) 的整数的单个 'number' 列(UInt64)的表。numbers(N, M, S)
- 返回一个包含从 N 到 (N + M - 1) 的整数的单个 'number' 列(UInt64)的表,步长为 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);
示例
-- Generate a sequence of dates from 2010-01-01 to 2010-12-31
select toDate('2010-01-01') + number as d FROM numbers(365);