加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

Delphi XE3 – TDataSet的性能问题

发布时间:2020-12-15 09:50:33 所属栏目:大数据 来源:网络整理
导读:使用XE3程序进行数据处理的时间比使用XE2编译的相同程序多10倍.这是已知问题(可能主要指TStringField),报告到 QC 111942,但尚未修复.有没有人针对这个问题进行修复/解决? TIA Branko 解决方法 在XE5中也是如此.额外的流量和所有这些客户端 – 服务器的东西
使用XE3程序进行数据处理的时间比使用XE2编译的相同程序多10倍.这是已知问题(可能主要指TStringField),报告到 QC 111942,但尚未修复.有没有人针对这个问题进行修复/解决?

TIA Branko

解决方法

在XE5中也是如此.额外的流量和所有这些客户端 – 服务器的东西需要> 5 Mbit每秒(!)才能正常工作.我只使用TFDConnection和TFDQuery.特别是对于MySQL,速度与Delphi组件和第三方驱动程序(libmysql.dll)相同.如果您没有FireDAC,可以使用TSQLQuery替换TFDQuery.这是一个如何填充字符串网格的过程:

procedure SelGrid(sql:ansiString;Q:TFDQuery;grid:TStringGrid);
var i: integer;
begin
  Q.Close;
  Q.SQL.Text:='';
  Q.Open(sql);
  grid.ColCount:=Q.FieldCount;
  grid.RowCount:=1;
  while not Q.Eof do begin
    for i := 0 to grid.ColCount-1 do grid.Cells[i,grid.RowCount-1]:=Q.Fields.Fields[i].AsString;
    grid.RowCount:=grid.RowCount+1;
    Q.Next;
  end;
  Q.Close;
  if grid.RowCount>1 then grid.RowCount:=grid.RowCount-1;
  grid.Row:=0;
  //AutoSizeGridColumns(grid,30,200);
end;

这是VCL字符串网格.当然,你会考虑处理更新等问题,但是你没有更多的性能问题.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读