mORMot2 获取数据集(泛型)

mORMot2 获取数据集(泛型)

第14章 使用泛型

现代Delphi版本的一个特点是能够使用泛型。


var 
  aMale: TSQLBaby; 

Begin
  aMale := TSQLBaby.CreateAndFillPrepare(Client, 'Name LIKE ? AND Sex = ?',['A\%',ord(sMale)]);
try
  while aMale.FillOne do
   DoSomethingWith(aMale);
  finally
    aMale.Free;
  end; 
end;

可以被替换为


var 
  aList: TObjectList<TSQLBaby>;
  aMale: TSQLBaby;
 ...
begin 
  aList := Client.RetrieveList<TSQLBaby>(’Name LIKE ? AND Sex = ?’,[’A\%’,ord(sMale)]);
  try
    for aMale in aList do
      DoSomethingWith(aMale); 
  finally
    aList.Free;
  end;
end; 

如果你觉得这个更吸引人,那么你就有更多的选择了。但有一个缺点,这个版本会一次性将所有数据下载到内存中。通常这不是问题,但如果你有一个非常大的数据集,你可能会耗尽内存。在服务器上,那将是致命的。

posted @   海利鸟  阅读(122)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
点击右上角即可分享
微信分享提示