假设我有以下记录:
code sequence_no group_no
4 1 1
2 2 1
3 3 1
4 4 1
1 1 2
3 1 3
4 2 3
输出应该是:在同一个组内(按 group_no),代码列用第一个(按 sequence_no)不是 4 的代码进行更新。
所以输出应该是这样的:
code sequence_no group_no
2 1 1
2 2 1
2 3 1
2 4 1
1 1 2
3 1 3
3 2 3
这是我的代码,我的逻辑是如果 input.code == 4,则将下一个代码分配给 temp 变量。如果第一个记录代码 == 4 出于某种原因,这将不起作用。如果它== 4,我认为这个逻辑不会涵盖该组的最后一条记录。
type temporary_type=
record
decimal("\x01") l_code;
end;
temp :: scan(temp, in) =
begin
temp.l_code::
if (temp.l_code == 4) in.code
else temp.l_code;
end;
temp :: initialize(in) =
begin
temp.code :: in.code;
end;
out :: finalize(temp, in) =
begin
out.* :: in.*;
out.code :: temp.l_code;
end;