umaddaexecuted.pas

来自「一整套的源代码」· PAS 代码 · 共 66 行

PAS
66
字号
unit UMADDAExecuted;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, UMADDAInput, Provider, OraProvider, DB, MemDS, DBAccess, Ora,
  OraSmart, DBClient, UModel, MyTools, MyFactory, UMPSysEnv;

type
  TMADDAExecuted = class(TMADDAInput)
    DAExecute: TOraStoredProc;
  private
    { Private declarations }
  protected
    procedure PrepareQuery (Parameters : MyTools.IQueryParameters); override;
  public
    function GetKey : IKey; override;
    procedure DoctorAdviceExecute;
  end;

  TDAExecutedFactory = class(TModelFactory)
    function NewModel : TModel; override;
  end;

implementation

uses UDataModel, UPrimaryDataModel;

{$R *.dfm}

{ TDAExecutedFactory }

function TDAExecutedFactory.NewModel: TModel;
begin
  Result := TMADDAExecuted.Create(GetOwner);
end;

{ TMADDAExecuted }

procedure TMADDAExecuted.DoctorAdviceExecute;
begin
  if not GetDataSet.Active or GetDataSet.IsEmpty then Exit;
  DAExecute.ParamByName('l_inpatientid').AsInteger := GetDataSet.FieldByName('i_inpatientid').AsInteger;
  DAExecute.ParamByName('l_createby').AsInteger := MPSysEnv.EmployeeKey.GetKey;
  try
    DAExecute.ExecProc;
    ShowMessage('执行成功,请不要重复执行!'); 
  except
    on E: Exception do
      ShowMessage('发生错误: ' + E.Message);
  end;
end;

function TMADDAExecuted.GetKey: IKey;
begin
  Result := NewKey('I_INPATIENTID');
end;

procedure TMADDAExecuted.PrepareQuery(Parameters: IQueryParameters);
begin
  DataSet.ParamByName('I_SECTIONOFFICEID').AsInteger := MPSysEnv.SectionOfficeKey.GetKey;
end;

end.

⌨️ 快捷键说明

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