跳到主要内容
跳到主要内容

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);