1

これは私が構築しようとしているクライアント側関数であり、より一般化されており、TDBXReader を返すさまざまなサーバー側プロシージャを呼び出すことができます。現在は機能していますが、いくつかの問題に直面しており、あなたの助けが必要です:

  • (最も重要) このアプローチについてどう思いますか? 提案/アドバイスはありますか?
  • vLClient (実際には TSrvMethodClient です) を解放するにはどうすればよいですか?
  • Create メソッドに 2 番目の引数を渡すことができないのはなぜですか?

ありがとうございました。

function askServerTo_give(SQLConn: TSQLConnection; procName: String; cds: TClientDataSet): Boolean;
var
  ctx : TRttiContext;
  SrvRTTI: TRttiType;
  vLClient, vLReader: TValue;
  //LClient : TSrvMethodsClient;
begin
  Result := False;
  vLClient := nil;
  vLReader := nil;

  ctx := TRttiContext.Create;
  SrvRTTI := ctx.GetType(TSrvMethodsClient.ClassInfo);

  vLClient := SrvRTTI.GetMethod('Create').Invoke(SrvRTTI.AsInstance.MetaclassType, [ SQLConn.DBXConnection ] );

  //vLClient := SrvRTTI.GetMethod('Create').Invoke(SrvRTTI.AsInstance.MetaclassType, [ SQLConn.DBXConnection , False] ); // Error!  
  //LClient := TSrvMethodsClient.Create( SQLConn.DBXConnection, False);
  try
    vLReader := SrvRTTI.GetMethod( procName ).Invoke(vLClient, []);

    if (vLReader.AsObject as TDBXReader) <> nil then begin
      TDBXDataSetReader.CopyReaderToClientDataSet((vLReader.AsObject as TDBXReader), cds);
      Result := not cds.IsEmpty;
    end;
  finally
    (vLReader.AsObject as TDBXReader).Free; //FreeAndNil() doesn`t work
    //(vLClient.AsObject as TSrvMethodsClient).Free; // Error!  
    ctx.Free;
  end;
end;
4

1 に答える 1

1

Datasnapがリモートメソッドを呼び出す方法を複製していませんか?たとえば、「TSQLServerMethodコンポーネントを使用したサーバーメソッドの呼び出し」を参照してください。

于 2009-12-17T11:13:48.847 に答える