⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 storeinfo.pas

📁 物流管理系统是一个典型的数据库应用程序
💻 PAS
字号:
unit storeinfo;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, frame, ExtCtrls, StdCtrls,Grids, DBGrids, DB,
  Buttons;

type
  Tf_storeinfo = class(Tf_frame)
    Panel1: TPanel;
    Label1: TLabel;
    Label2: TLabel;
    Label3: TLabel;
    Label4: TLabel;
    Label5: TLabel;
    StoreSource: TDataSource;
    DBGrid1: TDBGrid;
    Label6: TLabel;
    Panel2: TPanel;
    Add: TBitBtn;
    Cancel: TBitBtn;
    Update: TBitBtn;
    Delete: TBitBtn;
    Label9: TLabel;
    Label10: TLabel;
    Label11: TLabel;
    Label7: TLabel;
    Field: TComboBox;
    Label8: TLabel;
    Query: TBitBtn;
    storename: TEdit;
    Nameshort: TEdit;
    Spec: TEdit;
    Defaultprice: TEdit;
    Barcode: TEdit;
    basicunit: TEdit;
    Value: TEdit;
    Stockunit: TEdit;
    Conversion: TEdit;
    procedure storenameKeyDown(Sender: TObject; var Key: Word;
      Shift: TShiftState);
    procedure BarcodeKeyPress(Sender: TObject; var Key: Char);
    procedure CancelClick(Sender: TObject);
    procedure AddClick(Sender: TObject);
    procedure UpdateClick(Sender: TObject);
    procedure DeleteClick(Sender: TObject);
    procedure QueryClick(Sender: TObject);
    procedure DefaultpriceKeyPress(Sender: TObject; var Key: Char);
    procedure FormShow(Sender: TObject);
    procedure DBGrid1DblClick(Sender: TObject);
  private
    { Private declarations }
  public
    Procedure ClearEdit;//清空编辑框中的文本
    Function TextIsNull: Boolean;//判断编辑框中的文本是否为空
    Procedure Editvalue;//将数据集中的数据显示在编辑框中
    { Public declarations }
  end;

var
  f_storeinfo: Tf_storeinfo;

implementation
  uses data;
{$R *.dfm}

procedure Tf_storeinfo.storenameKeyDown(Sender: TObject; var Key: Word;
  Shift: TShiftState);
begin
  inherited;
  if Key = vk_Return then
    FindNext(True);
end;
//防止输入非法字符
procedure Tf_storeinfo.BarcodeKeyPress(Sender: TObject; var Key: Char);
begin
  inherited;
  if  not (Key in ['0'..'9',#8]) then
    Key := #0;
end;
//自定义过程,用于清空编辑框
procedure Tf_storeinfo.ClearEdit;
var
  i: Integer;
begin
  For i := 0 to Panel1.ControlCount-1 do
    if Panel1.Controls[i]is TEdit then
      TEdit(Panel1.Controls[i]).Clear;
end;

procedure Tf_storeinfo.CancelClick(Sender: TObject);
begin
  inherited;
  ClearEdit;
  Field.ItemIndex := 0;
  With t_data.Query1 do
  begin
    CLose;
    SQL.Clear;
    SQL.Add('Select * from tb_storeinfo');
    Open;
  end;
  if t_data.Query1.RecordCount>0 then
    StoreSource.DataSet := t_data.Query1
  else
  begin
    t_data.Query1.Close;
    StoreSource.DataSet := Nil;
  end;
end;

function Tf_storeinfo.TextIsNull: Boolean;
var
  i: Integer;
begin
  Result := False;
  For i := 0 to Panel1.ControlCount-1 do
    if Panel1.Controls[i] is TEdit then
    begin
      if Trim(TEdit(Panel1.Controls[i]).Text)='' then
      begin
        Result := True;
        Break;
      end;
    end;
end;
procedure Tf_storeinfo.AddClick(Sender: TObject);
begin
  inherited;
  if TextIsNull = False then
  begin
    With t_data.Query2 do
    begin
      CLose;
      SQL.Clear;
      SQL.Add('Select * from tb_storeinfo where storename = :name');
      Parameters.ParamByName('name').Value := Trim(Storename.Text);
      Open;
    end;
    if t_data.Query2.RecordCount>0 then
    begin
      Application.MessageBox('该物资名称已经存在,请重新输入.','提示',64);
      Storename.SelectAll;
      Storename.SetFocus;
      Exit;
    end;
    Try
      with t_data.Add1 do
      begin
        Close;
        SQL.Clear;
        SQL.Add('Insert into tb_storeinfo  Values (:storename,:shortname,:spec,:defaultprice,:barcode,:basicunit,:stockunit,:conversion)');
        Parameters.ParamByName('storename').Value := Trim(StoreName.Text);
        Parameters.ParamByName('shortname').Value := Trim(Nameshort.Text);
        Parameters.ParamByName('spec').Value := Trim(Spec.Text);
        Parameters.ParamByName('defaultprice').Value := StrToFloat(Defaultprice.Text);
        Parameters.ParamByName('barcode').Value := Trim(Barcode.Text);
        Parameters.ParamByName('basicunit').Value := Trim(Basicunit.Text);
        Parameters.ParamByName('stockunit').Value := Trim(Stockunit.Text);
        Parameters.ParamByName('conversion').Value := Trim(Conversion.Text);
        ExecSQL;
      end;
      Application.MessageBox('操作成功.','提示',64);
      Cancel.Click;
    Except
      On E: Exception do
        ShowMessage(E.Message);
    End;
  end
  else
  begin
    Application.MessageBox('物资信息不能为空.','提示',64);
  end;
end;

procedure Tf_storeinfo.UpdateClick(Sender: TObject);
begin
  inherited;
  if t_data.Query1.Active then
  begin
    if TextIsNull = False then
    begin
      if Application.MessageBox(Pchar('确实要修改物资名称为: '+t_data.Query1.FieldByName('storename').AsString+' 的物资信息吗?'),'提示',mb_YesNo)= ID_Yes then
      begin
        Try
          With t_data.update1 do
          begin
            CLose;
            SQL.Clear;
            SQL.Add('update tb_storeinfo set storename = :name,nameshort = :short,spec =:spec,defaultprice = :defaultprice,barcode = :barcode,basicunit = :basicunit,stockunit = :stockunit,conversion = :conversion where storename = :oldname');
            Parameters.ParamByName('name').Value := Trim(Storename.Text);
            Parameters.ParamByName('short').Value := Trim(Nameshort.Text);
            Parameters.ParamByName('spec').Value := Trim(spec.Text);
            Parameters.ParamByName('defaultprice').Value := StrToFloat(Defaultprice.Text);
            Parameters.ParamByName('barcode').Value := Trim(Barcode.Text);
            Parameters.ParamByName('basicunit').Value := Trim(Basicunit.Text);
            Parameters.ParamByName('stockunit').Value := Trim(Stockunit.Text);
            Parameters.ParamByName('conversion').Value := StrToFloat(Conversion.Text);
            Parameters.ParamByName('oldname').Value := Trim(t_data.Query1.FieldByName('storename').AsString);
            ExecSQL;
          end;
          Application.MessageBox('修改成功.','提示',64);
          Cancel.Click;
        Except
          On E: Exception do
            ShowMessage(E.Message);
        End;
      end;
    end
    else
      Application.MessageBox('物资信息不能为空.','提示',64);
  end
  else
    Application.MessageBox('当前没有可修改的数据.','提示',64);
end;

procedure Tf_storeinfo.DeleteClick(Sender: TObject);
begin
  inherited;
  if t_data.Query1.Active then
  begin
    if Application.MessageBox(Pchar('确实要删除物资名称为: ' + Trim(t_data.Query1.FieldByName('storename').AsString)+' 的物资信息吗?'),'提示',mb_YesNo)= ID_Yes then
    begin
      Try
        t_data.Query1.Delete;
        Cancel.Click;
      Except
        On E: Exception do
          ShowMessage(E.Message);
      End;
    end
  end
  else
    Application.MessageBox('当前没有可删除的信息.','提示',64);
end;
//处理查询按钮的单击事件
procedure Tf_storeinfo.QueryClick(Sender: TObject);
begin
  inherited;
  if t_data.Query1.Active then
  begin
    With t_data.Query1 do
    begin
      CLose;
      SQL.Clear;
      SQL.Add('select * from tb_storeinfo where ');
      if Field.ItemIndex = 0 then
      begin
        SQL.Add('storename Like :Value');
        Parameters.ParamByName('Value').Value := '%'+Trim(Value.Text)+'%';
      end
      else
      begin
        if Field.ItemIndex = 1 then
          SQL.Add('nameshort ')
        else
          SQL.Add('barcode ');
        SQL.Add(' = :Value');
        Parameters.ParamByName('value').Value := Trim(Value.Text);
      end;
      Open;
    end;
    if t_data.Query1.RecordCount<1 then
    begin
      Cancel.Click;
      Application.MessageBox('没有找到符合条件的记录.','提示',64);
    end;
  end
  else
    Application.MessageBox('当前没有可查询的数据.','提示',64);
end;
//防止输入非法字符,只允许输入数字
procedure Tf_storeinfo.DefaultpriceKeyPress(Sender: TObject;
  var Key: Char);
begin
  inherited;
  if Sender is TEdit then
  begin
    if  not (Key in ['0'..'9','.',#8]) then
      Key := #0;
    if key = '.' then
      if Pos('.',Trim(TEdit(Sender).Text)) <>0 then
        Key := #0;
  end;
end;

procedure Tf_storeinfo.FormShow(Sender: TObject);
begin
  inherited;
  Cancel.Click;
end;

procedure Tf_storeinfo.DBGrid1DblClick(Sender: TObject);
begin
  inherited;
  if t_data.Query1.Active then
    Editvalue;
end;

procedure Tf_storeinfo.Editvalue;
begin
  with t_data.Query1 do
  begin
    Storename.Text := Trim(FieldByName('storename').AsString);
    Nameshort.Text := Trim(FieldByName('nameshort').AsString);
    Spec.Text := Trim(FieldByName('spec').AsString);
    Defaultprice.Text := Trim(FieldByName('Defaultprice').AsString);
    Barcode.Text := Trim(FieldByName('Barcode').AsString);
    Basicunit.Text := Trim(FieldByName('basicunit').AsString);
    Stockunit.Text := Trim(FieldByName('stockunit').AsString);
    Conversion.Text := Trim(FieldByName('Conversion').AsString);
  end;
end;

end.

⌨️ 快捷键说明

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