1

假设我有以下记录:

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;
4

0 回答 0