?? savemoney.pas
字號:
unit SaveMoney;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, BaseMoney, DB, ADODB, Grids, DBGridEh, ExtCtrls, StdCtrls,
Buttons;
type
TSaveMoneyForm = class(TBaseMoneyForm)
Label2: TLabel;
Edit2: TEdit;
Label3: TLabel;
Edit3: TEdit;
procedure Edit1Exit(Sender: TObject);
procedure Edit3Enter(Sender: TObject);
procedure FormShow(Sender: TObject);
procedure Edit3KeyPress(Sender: TObject; var Key: Char);
procedure btnExecute1Click(Sender: TObject);
procedure BitBtn1Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;
procedure ShowSaveMoneyForm;
implementation
uses SysPublic, MoneyRecord;
{$R *.dfm}
procedure ShowSaveMoneyForm;
var
SaveMoneyForm: TSaveMoneyForm;
begin
SaveMoneyForm:= TSaveMoneyForm.Create(Nil);
SaveMoneyForm.ShowModal;
end;
procedure TSaveMoneyForm.Edit1Exit(Sender: TObject);
begin
inherited;
if not ADOQuery1.Active then Exit;
if ADOQuery1.RecordCount <1 then exit;
Edit2.Text:= '';
Edit2.Text:= ADOQuery1.FieldByName('會員編號').AsString;
end;
procedure TSaveMoneyForm.Edit3Enter(Sender: TObject);
begin
inherited;
if not ADOQuery1.Active then
Exit
else
begin
ADOQuery2.Close;
ADOQuery2.SQL.Clear;
ADOQuery2.SQL.Add('Select * From New會員金額設置 where 會員編號 =:Param1 and 類型=''0''');
ADOQuery2.Parameters.ParamByName('Param1').Value := ADOQuery1.FieldByName('會員編號').AsString;
ADOQuery2.Open;
end;
end;
procedure TSaveMoneyForm.FormShow(Sender: TObject);
begin
inherited;
btnExecute1.Caption:= '存 款';
btnExecute2.Caption:= '退 出';
end;
procedure TSaveMoneyForm.Edit3KeyPress(Sender: TObject; var Key: Char);
begin
inherited;
//只能輸入數字和小數點
if (Key in ['0'..'9']=false) and (Key<> '.') and (key<>#8) then
key:=#0
end;
procedure TSaveMoneyForm.btnExecute1Click(Sender: TObject);
var
fEdit, fMoney, fConversion, fTotal: Double;
ADOQryTmp :TADOQuery;
begin
inherited;
if not ADOQuery1.Active then exit;
if (Trim(Edit3.Text)= '') or (StrToFloat(Trim(Edit3.Text)) <=0) then
begin
ShowMsg('存款輸入值非法!');
Exit;
end;
ADOQryTmp:= TADOQuery.Create(Nil);
GetConn(ADOQryTmp);
ADOQryTmp.Close;
ADOQryTmp.SQL.Clear;
ADOQryTmp.SQL.Add('Select * From 優惠設置表 Where ID=1');
ADOQryTmp.Open;
fMoney:= ADOQryTmp.FieldByName('金額').AsFloat;
fConversion:= ADOQryTmp.FieldByName('轉').AsFloat;
fEdit:= StrToFloat(Edit3.Text);
fTotal:= fEdit + trunc(fEdit/fMoney)*fConversion;
try
ADOQuery1.Edit;
ADOQuery1.FieldByName('余額').AsFloat:= ADOQuery1.FieldByName('余額').AsFloat + fTotal;
ADOQuery1.FieldByName('總存款金額').AsFloat:= ADOQuery1.FieldByName('總存款金額').AsFloat + fTotal;
ADOQuery1.Post;
ADOQuery2.Append;
ADOQuery2.FieldByName('會員編號').AsString := ADOQuery1.FieldByName('會員編號').AsString;
ADOQuery2.FieldByName('會員名稱').AsString := ADOQuery1.FieldByName('會員名稱').AsString;
ADOQuery2.FieldByName('日期').AsDateTime := Now;
ADOQuery2.FieldByName('金額').AsFloat := fTotal;
ADOQuery2.FieldByName('操作員編號').AsString :=LoginEmployeCode;
ADOQuery2.FieldByName('操作員').AsString :=LoginEmployeName;
ADOQuery2.FieldByName('類型').AsString :='0';
ADOQuery2.Post;
ShowMsg('存款成功!');
Edit1.Text :='';
Edit2.Text :='';
Edit3.Text :='';
except
ShowMsg('存款失敗!');
end;
end;
procedure TSaveMoneyForm.BitBtn1Click(Sender: TObject);
begin
inherited;
ShowMoneyRecordForm(ADOQuery1, 0);
end;
end.
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -