关于Delphi内存表的使用说明

关于Delphi内存表的使用说明:1.建立临时表   数据输入是开发数据库程序的必然环节。在Client/Server结构中,客户端可能要输入一批数据后,再向服务器的后台数据库提交,这就需要在本地(客户端)建立临时数据表来存储用户输入的数据,待提交后,清除本地表数据。2 建立临时表如下:function CreateTableInMemory(const AFieldDefs:TFieldDefs):TDataSet; var TempTable:TClientDataSet; begin   TempTable:=nil;   Result:=nil;   if AFieldDefs<>nil then   begin    try   TempTable:=TClientDataSet.Create(Application);    TempTable.FieldDefs.Assign(AFieldDefs);    TempTable.CreateDataSet;    Result:=(TempTable as TDataSet);   Except    if TempTable<>nil then TempTable.Free;   Result:=nil;    raise;   end; end; end;//在程序中按如下方法使用: procedure TForm1.Button1Click(Sender: TObject); var ADataSet:TDataSet;  begin    ADataSet:=TDataSet.Create(Self);    with ADataSet.FieldDefs do    begin     Add('Name',ftString,30,False);    Add('Value',ftInteger,0,False);    end;  with DataSource1 do   begin    DataSet:=CreateTableInMemory(ADataSet.FieldDefs);    DataSet.Open; end;   ADataSet.Free; end; 一、 Delphi使用内存表1.1 Delphi创建内存表步骤:1. 创建一个Ttable实例。2. 设置一个DataBaseName为一个目录或是已有的数据库别名。3. 指定TableName的值。4. 设置TableType属性指明要创建的数据库表类型。(如果此属性为ttDefault表示数据库类型与TableName指定值的扩展名对应)。5. 调用TTable.FidldDefs对象的Add方法向数据库表中添加字段。Add有4个参数: 字段名:string。 字段类型:TfieldType。 字段大小:Word。一般只对String和Memo类型使用。 字段是否NotNull: Boolean。6. 使用TTable.IndexDefs.Add()方法定义索引。Add有三个参数: 索引名:string; 索引字段名:string; 索引类型:TIndexOptions;7. 调用TTable的CreateTable。这种方法适用于本地表。SQL表要用TQuery来创建。代码如下:varMemTable: TTable;beginwith MemTable.Create(Self) dobeginDatabaseName := 'c:\Temp';TableName := 'Test';TableType := ttParadox;with FieldDefs dobeginAdd('Age', ftInteger, 0, True);Add('Name', ftString, 25, False);Add('Weight', ftFloat, 0, False);end;IndexDefs.Add('', 'Age', [ixPrimary, ixUnique]);CreateTable;end;end;二、 kbmMemTable使用简述2.1 kbmMemTable创建步骤:1. 创建一个kbmMemTable对象实例。2. 调用kbmMemTable.FidldDefs对象的Add方法向数据库表中添加字段。Add的方法和Delphi相同。3. 使用kbmMemTable.IndexDefs.Add()方法定义索引。Add的方法和Delphi相同。4. 调用kbmMemTable的CreateTable。重要的区别:因为kbmMemTable不需要BDE的支持。所以不要指明DatabaseName, TableName和TableType三个属性。  代码如下:with kbmMemTable1 dobeginwith kbmMemTable1.FieldDefs dobeginClear;Add('Period', ftInteger, 0, false);Add('VALUE', ftLargeInt, 0, false);Add('BytesField', ftBytes, 20, false);Add('Color', ftInteger, 0, false);Add('Date', ftDate, 0, false);Add('Memo', ftMemo, 0, false);Add('AutoInc', ftAutoInc, 0, false);end;with kbmMemTable1.IndexDefs dobeginClear;Add('Index1', 'VALUE', []);end;CreateTable;end;三、与Delphi创建内存表的对比3.1主从表功能kbmMemTable可以象其它TDataSet一样,通过设置MasterSource和MasterField来简单的完成主从表的操作。3.2 SQL功能  没有发现kbmMemTable可以支持SQL语句的操作。它提供按字段排序和对排序字段的查找功能。三、 kbmMemTable特点从其它TDataSet得到数据。代码如下:LoadFromDataSet(Table1, [mtcpoStructure, mtcpoProperties]);这样kbmMemTable就完全得到来自一个DataSet对象中的全部数据.保存和载入内存表中数据的功能Delphi的TTable不提供SaveToFile功能。kbmMemTable提供保存到文件的功能,保存的文件有两种格式:Options: TkbmMemTable.SaveFlags; 1. 二进制格式。kbmMemTable.SaveToBinaryFile('c:\test.bin', Options).kbmMemTable1.LoadFromBinaryFile('c:\test.bin')2. .csv格式。kbmMemTable.SaveToFile('c:\test.csv', Options);kbmMemTable1.LoadFromFile('c:\test.csv')(一种Excel支持的文档格式)打开后的内容如下:@@FILE VERSION@@ 200 @@TABLEDEF START@@ Period=Integer,0,"Period","",10 VALUE=LargeInt,0,"VALUE","",15 BytesField=Bytes,20,"BytesField","",10 Color=Integer,0,"Color","",10 Date=Date,0,"Date","",10 Memo=Memo,0,"Memo","",10 AutoInc=AutoInc,0,"AutoInc","",10 CALC=String,20,"CALC","",20 @@TABLEDEF END@@ Period VALUE BytesField Color Date Memo AutoInc CALC1 198 0 02/11/2001 This is a memo%n2001-11-2 10:19:52 1 0 1-二月2 196 3 03/11/2001 This is a memo%n2001-11-2 10:19:52 2 1 2-三月在文档的头部份描述了表的字段结构,在下面则是数据区域。 

,Apple周一起提供浏览器Safari 1.0下载
2004-10-08
很多用户只想开通当月的爱奇艺会员来追某一部剧,却不知道爱奇艺会员开通后每个月都会自动续费,想取消爱奇艺自动续费功能却不知道入口在哪里,下面为大家带来爱奇艺怎么取消自动续费详细教程,希望能帮到大家。,爱奇艺会员怎么取消
2018-11-12
融媒体,为广大用户带来更加智能化多元化的本地新闻资讯与生活服务,通过融媒体app用户可以随时了解身边大事小情,体验便捷的政务服务,有需要就来下载.
2021-11-21
宅在家里不出门,外卖送到家门口!点外卖app通过GPS搜索附近热门店铺,不仅有美食,还有面包坊、奶茶饮品店等,点外卖软件除了午餐、晚餐、夜宵以外,大到生日蛋糕、过节礼包,小到零食、针头线脑,都能在点外卖app上一键搞定。这些点外卖软件app致力为您甄选资质齐全,卫生可靠的优质商家,提供安全、方便、快捷、贴心的高品质外卖服务。
2023-07-08
黎明之光手游排位赛要怎么打等级才高?很多玩家对黎明之光手游排位赛并不了解也不太敢打排位赛,下面小编就为各位玩家带来黎明之光手游排位赛实用攻略,让你轻松搞定排位赛!,黎明之光手游排位赛怎么打 黎明之光手游排位赛实用攻略
2016-08-30
纪念碑谷被遗忘的海岸第四关怎么过?纪念碑谷被遗忘的海岸第四关主要是需要利用水的重量和水位的关系来设计的关卡,游戏需要根据不同的水位到达不同的地方来解开下一歩,纪念碑谷被遗忘的海岸第四关怎么过 第四关攻略
2015-01-12
灵妖记杨戬怎么样,很多新手玩家们却不知道该伙伴怎么样!别着急,接下来就和小编一起来看下杨戬属性技能介绍!赶紧get起来吧!,灵妖记杨戬怎么样 杨戬属性技能介绍
2017-12-12
乐高世界这款别具一格的沙盒化游戏刚一发布就吸引了大量玩家,体验过该游戏的玩家们都大呼其好。乐高世界的存档对于玩家们来说也是很重要的,下面小编就为大家介绍乐高世界存档位置到底在哪,一起来看看吧,乐高世界存档位置在哪 乐高世界存档位置介绍
2015-06-03
战场女武神4DLC几章能用?不少新手玩家朋友们不知道DLC内容要怎么使用和解锁,下面我们就来介绍一下战场女武神4DLC奖励通关解锁内容吧,希望对各位玩家朋友们有所参考和帮助,战场女武神4DLC几章能用 战场女武神4DLC奖励通关解锁内容
2019-01-28
太吾绘卷内息紊乱怎么办?游戏中很多玩家遇到了内息紊乱的情况,出现这种情况的原因有多种,比如战斗或是练功的时候,下面带来太吾绘卷内息混乱解决方法,一起来看看吧,太吾绘卷内息混乱解决方法 太吾绘卷内息紊乱怎么办
2018-09-26