我确实有下表:
create table test_seq (id int, obs int);
insert into test_seq values (1,1);
insert into test_seq values (2,1);
insert into test_seq values (3,1);
insert into test_seq values (4,0);
insert into test_seq values (5,0);
insert into test_seq values (6,1);
insert into test_seq values (7,1);
insert into test_seq values (8,0);
insert into test_seq values (9,0);
insert into test_seq values (10,1);
insert into test_seq values (11,0);
是否有 SQL 方式,如何创建以下输出?
id obs seq_num
1 1 1
2 1 1
3 1 1
4 0 2
5 0 2
6 1 3
7 1 3
8 0 4
9 0 4
10 1 5
11 0 6
每次 obs 列中的值与前一行(按 id 排序)相比发生变化时,seq_num 都会增加 1。我可以在 Excel 中轻松解决这个问题(使用简单的 if 公式),但在 postgres 中无法解决这个问题。