3

我有一个与此非常相似的代码来复制TADODataSet组件及其事件。

所以,如果我有一个ADODataSet1我想创建一个新实例ADODataSet2作为前一个组件的完全相同的组件。

一切正常,但我仍然无法复制流字段ADODataSet1PollID, ADODataSet1Title, ADODataSet1Description):

object ADODataSet1: TADODataSet
  Connection = ADOConnection1
  CursorType = ctStatic
  AfterOpen = ADODataSet1AfterOpen
  CommandText = 'select top 10  * from Polls'
  Parameters = <>
  Left = 224
  Top = 40
  object ADODataSet1PollID: TGuidField
    FieldName = 'PollID'
    FixedChar = True
    Size = 38
  end
  object ADODataSet1Title: TWideStringField
    FieldName = 'Title'
    Size = 255
  end
  object ADODataSet1Description: TWideStringField
    FieldName = 'Description'
    Size = 4000
  end      
end

我遇到的另一个问题是,如果ADODataSet1设置为Active=True,那么当我调用时ms.ReadComponent(Dest)Active流式传输之前 Connection会引发异常缺少连接或连接字符串”。False写后如何将 Active 设置为ms.WriteComponent(Source)?(一种解决方法是ADODataSet1.Active := False在复制之前进行设置)。

注意:我不想在数据集(TADODataSet.Clone)上克隆游标/记录集,所以请不要将其视为“重复问题”。

4

1 回答 1

0

尝试这个 :

Procedure registerAllClass(CMP: TComponent);
var
  I:Integer;
begin
  if (CMP is TPersistent) then begin
    RegisterClass(TPersistentclass(cmp.ClassType));
  end;
  for I:=0 to CMP.ComponentCount-1 do
    registerAllClass(cmp.Components[i]);
end;

function DuplicateComponent(Component: TComponent): TComponent;
var
  MemStream: TMemoryStream;
  oldname:String;
begin
  oldname:=component.Name;
  try
      registerAllClass(Component);
      Component.Name:='CopyOf'+Component.Name;
      MemStream := TMemoryStream.Create;
      try
        MemStream.WriteComponent(Component);
        MemStream.Position := 0;
        result:=MemStream.ReadComponent(nil);
      finally
        MemStream.Free;
      end;
  finally
    Component.Name:=oldname;
  end;
end;

function DuplicateDataset(Dataset:TDataset):TDataset;
var
  oldActive:Boolean;
begin
  if Dataset=nil then
    result:=nil
  else begin
    oldActive:=Dataset.Active;
    try
      Dataset.Active:=false;
      result:=DuplicateComponent(Dataset) as TDataSet;
    finally
      Dataset.Active:=oldActive;
    end;
  end;  
end;
于 2012-05-09T12:07:10.060 回答