1

我有一个包含一列整数的表 - 我需要一种方法来在另一个表中生成该列的“前缀”。

例如

我有 1, 0, 0, 0, 1, 0, 1, 0, 0 作为输入
我需要 1, 1, 1, 1, 2, 2, 3, 3, 3 作为输出

这需要在 SQLite 的 SQL 方言中完成,没有用户定义的函数或存储过程是可能的。

4

2 回答 2

1

尝试这样的事情:

select value,
(select sum(t2.value) from table t2 where t2.id <= t1.id ) as accumulated
from table t1

来自:SQLite:SELECT 语句中的累加器(总和)列

于 2010-10-13T14:16:50.507 回答
1

因此,要从input一个表插入到另一个表,output您需要以下查询:

INSERT INTO output
SELECT id,
(SELECT sum(i1.value) FROM input AS i1 WHERE i1.rowid  <= i2.rowid) as VALUE
FROM input AS i2
于 2010-10-13T14:42:03.140 回答