0

所以我有一个以下格式的层次结构表:

Instance | Parent | Serial | Hierarchy Level
    1    |   0    |   x0   |         1
    2    |   0    |   x1   |         1
    3    |   1    |   xy0  |         2
    4    |   1    |   xy1  |         2
    5    |   2    |    -   |         2
    6    |   2    |    -   |         2
    7    |   2    |    -   |         2

我想得到的是:

Instance | Parent | Serial | Hierarchy Level
    1    |   0    |   x0   |         1
    2    |   0    |   x1   |         1
    3    |   1    |   xy0  |         2
    4    |   1    |   xy1  |         2
    5    |   1    |   x0   |         2
    6    |   2    |   x1   |         2
    7    |   2    |   x1   |         2

所有级别 1 都有一个序列号。我的目标是更新 Serial 为空的所有 2 级,为此,我必须选择父级的序列号。有人可以给我一个如何去做的想法。

这是我迄今为止尝试过的(以及其他几件事,无济于事):

UPDATE "USER"."TABLE" AS A1
SET A1.SERIAL = 
(
    SELECT "SERIAL" 
    FROM "USER"."TABLE" AS A2
    WHERE A2."PARENT" = A1."INSTANCE" 
)
WHERE "SERIAL" IS NULL
AND "HIERARCHYLEVEL" = 2

原生于java,我觉得这应该容易得多,但是我遇到了很多困难。任何帮助将非常感激。

4

1 回答 1

0

对不起这个愚蠢的问题。正如@rd_nielsen 在 OP 回复中解释的那样,简单的修复方法:

UPDATE "user"."table" AS A1
SET A1.serial = 
(
    SELECT "serial" 
    FROM "user"."table" AS A2
    WHERE A1."PARENT"  = A2."INSTANCE"
)
WHERE "serial" IS NULL
AND "HIERARCHYLEVEL" = 2
于 2017-06-21T21:46:38.023 回答