我需要迭代一些MySQL查询,并将它们保存在一个TMemDataset数组中。
MemDataset1.CopyFromDataset(ZQuery1,True); 然而,每次查询更改时,所有以前的TMemDataset都会被更改为包含新值(我猜是因为它们是“数据感知组件”)。如果我用ZQuery1.Free去掉了ZQuery1,那么所有数据都会消失。我该如何避免这种情况呢?
我使用的是FreePascal,但我打赌Delphi的解决方案也会适用。
发布于 2012-05-20 23:13:16
解决方案是拥有一个ZQuery数组和一个MemDataSet数组
type
TZQueries = array of TZQuery;
TMemDataSets = array of TMemDataset;
procedure Test;
var
ZQueries: TZQueries;
MemDatasets: TMemDatasets;
i: integer;
begin
try
SetLength(ZQueries,10);
SetLength(MemDatasets,10);
for i:= Low(ZQueries) to high(ZQueries) do begin
ZQueries[i]:= TZQuery.Create;
ZQueries[i].Connection:= ZConnection1;
ZQueries[i].SQL.Text:= QueryTextFromSomewhere
end; {for i}
for i:= Low(MemDatasets) to High(MemDatasets) do begin
MemDatasets[i]:= TMemDataset.Create;
ZQueries[i].Open;
MemDatasets[i].CopyFromDataset(ZQueries[i],True);
end; {for i}
....
code to process the memdatasets
....
finally
for i = Low(ZQueries) to High(ZQueries) do begin
ZQueries[i].Free;
end; {for i}
for i = Low(MemDatasets) to High(MemDatasets) do begin
MemDatasets[i].Free;
end; {for i}
end; {tryf}
end;这样的东西应该可以工作,因为现在在查询和memdataset之间不再有混淆。
https://stackoverflow.com/questions/8200136
复制相似问题