delphi KbmMemTable的简单应用(增删改查示例)  
官方Delphi 学习QQ群: 682628230(三千人)
频道

delphi KbmMemTable的简单应用(增删改查示例)


KbmMemTable的简单应用(增删改查示例)

//kbmMemTable
unit Unit1;

interface

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

type
 TForm1 = class(TForm)
   Button1: TButton;
   DataSource1: TDataSource;
   DBGrid1: TDBGrid;
   Button2: TButton;
   Button3: TButton;
   Button4: TButton;
   Button5: TButton;
   Button6: TButton;
   Button7: TButton;
   procedure Button1Click(Sender: TObject);
   procedure FormCreate(Sender: TObject);
   procedure Button2Click(Sender: TObject);
   procedure Button4Click(Sender: TObject);
   procedure Button3Click(Sender: TObject);
   procedure Button5Click(Sender: TObject);
   procedure Button6Click(Sender: TObject);
   procedure Button7Click(Sender: TObject);
 private
   { Private declarations }
 public
   { Public declarations }
 end;

var
 Form1: TForm1;
 kbmMemTable1 : TkbmMemTable;
 Id:Integer;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
begin
 //建表
 kbmMemTable1.FieldDefs.Clear;
 kbmMemTable1.FieldDefs.Add('Id', ftInteger, 0, False);
 kbmMemTable1.FieldDefs.Add('Value', FtString, 20, False);
 kbmMemTable1.FieldDefs.Add('Time', ftDateTime, 0, False);
 kbmMemTable1.IndexDefs.Add('Index1','Id',[]);//定义索引
 kbmMemTable1.CreateTable;
 kbmMemTable1.Active := True;
end;

procedure TForm1.Button2Click(Sender: TObject);
var
 fld_Id:TIntegerField;
 fld_Value:TStringField;
 fld_Time:TDateTimeField;
 i:Integer;
begin
 //插入
 with kbmMemTable1 do
 begin
   DisableControls; //切断数据感知控件
   try
     Open; //打开
     //定义Field
     fld_Id:=TIntegerField(FieldByName('Id'));
     fld_Value:=TStringField(FieldByName('Value'));
     fld_Time:=TDateTimeField(FieldByName('Time'));
     for i := 0 to 9 do
     begin
       Inc(Id);
       Append; //附加数据
       //赋值
       fld_Id.AsInteger := Id;
       fld_Value.AsString := 'Hello PFeng!'+inttostr(Id);
       fld_Time.AsDateTime := Now;
       Post; //确定
     end;
     UpdateIndexes;//更新索引
   finally
     EnableControls; //连接数据感知控件
   end;
 end;
end;

procedure TForm1.Button3Click(Sender: TObject);
var
 fld_Id:TIntegerField;
 fld_Value:TStringField;
 fld_Time:TDateTimeField;
begin
 //更新
 with kbmMemTable1 do
 begin
   Open;
   fld_Id:=TIntegerField(FieldByName('Id'));
   fld_Value:=TStringField(FieldByName('Value'));
   fld_Time:=TDateTimeField(FieldByName('Time'));
   if Locate('Id',5,[]) then
   begin
     Edit;
     fld_Value.AsString := '内容被修改';
     fld_Time.AsDateTime := Now;
     Post;
   end;
 end;
end;

procedure TForm1.Button4Click(Sender: TObject);
var
 fld_Id:TIntegerField;
 fld_Value:TStringField;
 fld_Time:TDateTimeField;
begin
 //查询
 with kbmMemTable1 do
 begin
   Open;
   fld_Id:=TIntegerField(FieldByName('Id'));
   fld_Value:=TStringField(FieldByName('Value'));
   fld_Time:=TDateTimeField(FieldByName('Time'));
   if Locate('Id',5,[]) then
   ShowMessage(fld_Value.AsString);
   //还可以用FindKey实现,结合索引速度更快
   // kbmMemTable1.IndexFieldNames:='Id';
   // if kbmMemtable1.FindKey([5]) then ...
 end;
end;

procedure TForm1.Button5Click(Sender: TObject);
var
 fld_Id:TIntegerField;
 fld_Value:TStringField;
 fld_Time:TDateTimeField;
begin
 //删除
 with kbmMemTable1 do
 begin
   Open;
   fld_Id:=TIntegerField(FieldByName('Id'));
   fld_Value:=TStringField(FieldByName('Value'));
   fld_Time:=TDateTimeField(FieldByName('Time'));
   if Locate('Id',5,[]) then
   begin
     Delete;
     UpdateIndexes;
   end;
 end;
end;

procedure TForm1.Button6Click(Sender: TObject);
var
 fld_Id:TIntegerField;
 fld_Value:TStringField;
 fld_Time:TDateTimeField;
 id:Integer;
begin
 //循环比较最小值
 with kbmMemTable1 do
 begin
   Open;
   fld_Id:=TIntegerField(FieldByName('Id'));
   fld_Value:=TStringField(FieldByName('Value'));
   fld_Time:=TDateTimeField(FieldByName('Time'));
   DisableControls;
   try
     First;
     id := fld_Id.AsInteger;
     while not Eof do
     begin
       if id > fld_Id.AsInteger then
       id := fld_Id.AsInteger;
       Next;
     end;
     Locate('Id',id,[]);
   finally
     EnableControls;
   end;
 end;
end;

procedure TForm1.Button7Click(Sender: TObject);
begin
 //清空
 kbmMemTable1.EmptyTable;
end;

procedure TForm1.FormCreate(Sender: TObject);
begin
 kbmMemTable1 := TkbmMemTable.Create(Self);
 DataSource1.DataSet := kbmMemTable1;
end;

end.

KbmMemTable是一款高效且强大的内存表控件,内存表顾名思义其最大的优势就是速度,KbmMemTable不仅完美地实现了高效的特征,同时,最新版本还支持索引、SQL语句等高级用法。其用法超简单,基本用法和ClientDataSet一致,以下是我简单的应用示例,实现了增删改查等基本功能:


推荐分享
图文皆来源于网络,内容仅做公益性分享,版权归原作者所有,如有侵权请告知删除!
 

Copyright © 2014 DelphiW.com 开发 源码 文档 技巧 All Rights Reserved
晋ICP备14006235号-8 晋公网安备 14108102000087号

执行时间: 0.18498182296753 seconds