通过名称的字符串表示形式引用表

时间:2013-08-30 13:28:59

标签: progress-4gl

我正在尝试编写一个模块化过程,在其中传入表名的字符串表示形式,并查询/更新该表。

我尝试的是这件事:

PROCEDURE foo:
    DEFINE INPUT PARAMETER chTableName AS CHARACTER NO-UNDO.
    FIND FIRST VALUE(chTableName) NO-LOCK
    WHERE blahblahblah NO-ERROR.

    IF AVAIL VALUE(chTableName) THEN
    ASSIGN
         VALUE(chTableName).value = foo.
END PROCEDURE.

这显然不起作用,但希望这可以解决我想要完成的任务。

此事的任何帮助或信息将不胜感激。感谢。

2 个答案:

答案 0 :(得分:3)

希望您运行的是版本9或更高版本的动态查询。

procedure x:

  define input parameter tbl as character no-undo.
  define input parameter fld as character no-undo.
  define input parameter xyz as character no-undo.

  define variable qh as handle no-undo.
  define variable bh as handle no-undo.
  define variable fh as handle no-undo.

  create buffer bh for table tbl.
  create query qh.
  qh:set-buffers( bh ).
  qh:query-prepare( "for each " + tbl ).
  qh:query-open.

  do transaction:
    qh:get-first( exclusive-lock ).
    fh = bh:buffer-field( fld ).
    display fh:buffer-value.
    fh:buffer-value = xyz.
  end.

  delete object bh.
  delete object qh.

  return.

end.

run x ( "customer", "name", "fred" ).

find first customer no-lock.
display name.

答案 1 :(得分:2)

这可以帮助您入门:

DEFINE TEMP-TABLE tt NO-UNDO
    FIELD a AS INTEGER.

PROCEDURE foo:
    DEFINE INPUT  PARAMETER pcTable AS CHARACTER   NO-UNDO.
    DEFINE INPUT  PARAMETER pcWhere AS CHARACTER   NO-UNDO.
    DEFINE INPUT  PARAMETER pcField AS CHARACTER   NO-UNDO.
    DEFINE INPUT  PARAMETER piValue AS INTEGER     NO-UNDO.

    DEFINE VARIABLE hBuffer AS HANDLE      NO-UNDO.
    DEFINE VARIABLE hQuery  AS HANDLE      NO-UNDO.

    CREATE BUFFER hBuffer FOR TABLE pcTable.
    CREATE QUERY hQuery.   

    hQuery:SET-BUFFERS(hBuffer).

    hQuery:QUERY-PREPARE("FOR EACH " + pcTable + " WHERE " + pcWhere).

    hQuery:QUERY-OPEN().
    hQuery:GET-FIRST().

    IF hBuffer:AVAILABLE THEN DO:
        ASSIGN 
            hBuffer:BUFFER-FIELD(pcField):BUFFER-VALUE = piValue NO-ERROR.
        IF ERROR-STATUS:ERROR THEN DO:
            MESSAGE "Failed" VIEW-AS ALERT-BOX ERROR.
        END.
    END.

    DELETE OBJECT hBuffer.
    DELETE OBJECT hQuery.


END PROCEDURE.

CREATE tt.
ASSIGN tt.a = 1.


RUN foo( INPUT "tt"
       , INPUT "tt.a = 1"
       , INPUT "a"
       , INPUT 2).

DISPLAY tt.