从Browse和Create Temp Table获取值

时间:2012-02-17 07:16:59

标签: progress-4gl openedge

我有一个动态的Browser.It将根据UI提供的一些输入动态填充值。

现在我想获得浏览中显示的值并为其创建临时表。 请帮忙

1 个答案:

答案 0 :(得分:2)

要添加新值,首先要在temp-table中插入一个新行,然后安排更新该行。以下代码很难看,但它可以用来说明:

define temp-table tt_simple no-undo
  field id   as integer
  field name as character
  index id_idx is unique id
.

define variable r as integer no-undo.

define query q for tt_simple.

define browse b query q display tt_simple.name with 5 down.

form b with frame easy.

form
  tt_simple.name
 with
  frame updEasy
  column 30
  row 1
.

procedure newRecord:
  define input parameter initName as character no-undo.
  create tt_simple.
  assign
    r    = r + 1
    id   = r
    name = initName
  .
end.

run newRecord( "abc" ).
run newRecord( "xyz" ).

on "enter" of b in frame easy do:
  apply "entry" to tt_simple.name in frame updEasy.
  return no-apply.
end.

on "insert-mode", "CTRL-I" anywhere do:
  run newRecord( "" ).
  close query q.
  open query q for each tt_simple.
  get last q.
  apply "entry" to tt_simple.name in frame updEasy.
  return no-apply.
end.

on "go" of tt_simple.name in frame updEasy do:
  tt_simple.name = self:screen-value.
  close query q.   
  open query q for each tt_simple.
  apply "entry" to b in frame easy.
  return no-apply.
end.

on "value-changed" of b in frame easy do:
  display tt_simple.name with frame updEasy.
end.

open query q for each tt_simple.

enable tt_simple.name with frame updEasy.
enable b with frame easy.
apply "entry" to b in frame easy.

wait-for "close" of this-procedure.