unit2.~pas

来自「三层数据库应用程序的例子,包括应用服务器和前台程序.」· ~PAS 代码 · 共 72 行

~PAS
72
字号
unit Unit2;

{$WARN SYMBOL_PLATFORM OFF}

interface

uses
  Windows, Messages, SysUtils, Classes, ComServ, ComObj, VCLCom, DataBkr,
  DBClient, Project1_TLB, StdVcl, Provider, ADODB, DB;

type
  TTestServer = class(TRemoteDataModule, ITestServer)
    ADOConnection1: TADOConnection;
    ADOTable1: TADOTable;
    ADOQuery1: TADOQuery;
    ADOStoredProc1: TADOStoredProc;
    DataSetProvider1: TDataSetProvider;
    DataSetProvider2: TDataSetProvider;
    DataSetProvider3: TDataSetProvider;
    procedure RemoteDataModuleCreate(Sender: TObject);
    procedure RemoteDataModuleDestroy(Sender: TObject);
    procedure ADOQuery1AfterOpen(DataSet: TDataSet);
  private
    { Private declarations }
  protected
    class procedure UpdateRegistry(Register: Boolean; const ClassID, ProgID: string); override;
  public
    { Public declarations }
  end;

implementation

uses Unit1;

{$R *.DFM}

class procedure TTestServer.UpdateRegistry(Register: Boolean; const ClassID, ProgID: string);
begin
  if Register then
  begin
    inherited UpdateRegistry(Register, ClassID, ProgID);
    EnableSocketTransport(ClassID);
    EnableWebTransport(ClassID);
  end else
  begin
    DisableSocketTransport(ClassID);
    DisableWebTransport(ClassID);
    inherited UpdateRegistry(Register, ClassID, ProgID);
  end;
end;

procedure TTestServer.RemoteDataModuleCreate(Sender: TObject);
begin
  //增加一位前台的在线者(调用Form1上的过程)
  Form1.UpdateClientCount(1);
end;

procedure TTestServer.RemoteDataModuleDestroy(Sender: TObject);
begin
  Form1.UpdateClientCount(-1);
end;

procedure TTestServer.ADOQuery1AfterOpen(DataSet: TDataSet);
begin
  Form1.incQueryCount;
end;

initialization
  TComponentFactory.Create(ComServer, TTestServer,
    Class_TestServer, ciMultiInstance, tmApartment);
end.

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?