使用动态创建TFDQuery
的 , TClientDataSet
,TDataSetProvider
我遇到了“缺少数据提供者或数据包”的代码:
procedure ResetSavedPasswords(ADataModuleDataBaseAdmin : TDataModuleDataBaseAdmin);
var
lQuery : TFDQuery;
lCDS : TClientDataSet;
lProvider : TDataSetProvider;
begin
lFrmBezig := TFormBezig.Create(nil);
lQuery := TFDQuery.Create(nil);
lProvider := TDataSetProvider.Create(Application);
lCDS := TClientDataSet.Create(nil);
try
lQuery.Connection := ADataModuleDataBaseAdmin.FDConnectionTimeTell;
lQuery.CachedUpdates := true;
lProvider.Options := lProvider.Options - [poUseQuoteChar];
lProvider.DataSet := lQuery;
lProvider.Name := 'prvResetSavedPW';
lCDS.ProviderName := lProvider.Name;
lQuery.SQL.Text := Format('select %s,%s from <owner>%s',[sMedMedID,sMedSavedPassword,SMedTabelNaam]),ADataModuleDataBaseAdmin;
lCDS.Open;
请注意,创建的TDataSetProvider
有一个所有者,基于这个答案:
如果 DatasetProvider 没有所有者,则 ClientDataSet 无法获取对提供者的引用
但我仍然得到错误。打开第TFDQuery
一个显示它有数据。
可能是什么原因?
在 Delphi 10.4 中使用 FireDAC。悉尼在 Win32 应用程序中。