由于用户一次输入的数据量一般情况下较小(不会超过几百条记录),所以临时表可以建立在内存中,这样处理速度较快。 方法1:使用查询控件(TQuery) 第1步:在窗体上放上查询控件(TQuery),设置好所连接的数据表。 第2步:使TQuery. CachedUpdates=True; TQuery. RequestLive=True 第3步:在原有的SQL语句后加入一条Where子语句,要求加入这条Where子语句后SQL查询结果为空。 例如: SELECT Biolife.″Species No″, Category, Common_Name, Biolife.″Species Name″, Biolife.″Length (cm)″, Length_In, Notes, Graphic FROM ″biolife.db″ Biolife where Biolife.Category=′A′ and Biolife.Category=′B′ 这样临时表就建立完成了。
方法2:使用代码创建临时表 代码如下: function CreateTableInMemory(const AFieldDefs:TFieldDefs):TDataSet; var TempTable:TClientDataSet; begin TempTable:=nil; Result:=nil; if AFieldDefs$#@60;$#@62;nil then begin try TempTable:=TClientDataSet.Create(application); TempTable.FieldDefs.Assign(AFieldDefs); TempTable.CreateDataSet; Result:=(TempTable as TDataSet); Except if TempTable$#@60;$#@62;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(′ ue′,ftInteger,0,False); end;
with DataSource1 do begin DataSet:=CreateTableInMemory(ADataSet.FieldDefs); DataSet.Open; end;