-
numbers()– 返回一个无限表,其中只有一个number列 (UInt64) ,按升序包含从 0 开始的整数。使用LIMIT(以及可选的OFFSET) 可限制返回的行数。 -
numbers(N)– 返回一个只有单个number列 (UInt64) 的表,该列包含从 0 到N - 1的整数。 -
numbers(N, M)– 返回一个只有单个number列 (UInt64) 的表,该列包含从N到N + M - 1的M个整数。 -
numbers(N, M, S)– 返回一个只有单个number列 (UInt64) 的表,该列包含区间[N, N + M)内按步长S递增的值 (约为M / S行,向上取整) 。S必须>= 1。
system.numbers 系统表类似。可用于测试和生成连续值。
以下查询是等价的:
示例
>= 10^15 的 UInt64,其 sipHash64(number) 的末尾有 20 个零位。
注意事项
- 出于性能考虑,如果你知道自己需要多少行,建议优先使用有界形式 (
numbers(N)、numbers(N, M[, S])) ,而不是无界的numbers()/system.numbers。 - 如需并行生成,请使用
numbers_mt(...)或system.numbers_mt表。请注意,返回结果的顺序可能是任意的。