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字符串网格.当然,你会考虑处理更新等问题,但是你没有更多的性能问题. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |