1

我正在像 Oracle 一样在雪花数据仓库中寻找带有循环的序列。我猜雪花数据仓库没有这个内置的。知道如何实施吗?

4

1 回答 1

1

虽然 Snowflake 目前不支持它(请考虑在 Snowflake 社区论坛中提交功能请求),但您可以(大部分)使用 UDF 来模拟它,例如:

create or replace sequence seq;
create or replace function cyclic_seq() returns int as 'mod(seq.nextval, 3)';
create or replace table x(s string, i int default cyclic_seq());

insert into x(s) values('a');
insert into x(s) values('b');
insert into x(s) values('c');
insert into x(s) values('d');
insert into x(s) values('e');
insert into x(s) values('f');

select * from x;
---+---+
 S | I |
---+---+
 a | 1 |
 b | 2 |
 c | 0 |
 d | 1 |
 e | 2 |
 f | 0 |
---+---+
于 2018-08-10T21:43:30.083 回答