- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 Delphi 10.1 Berlin 下使用 FireDac。
为了向用户显示数据,我使用 TDBEdit 等数据感知控件。
我使用 TFDQuery 和 TDataSource 将它们与控件链接。
这可行,但需要一些时间才能执行的长 SQL 查询会卡住 GUI。
我想知道如何在执行这些长时间运行的查询时阻止 gui 卡住。
我正在考虑后台线程。
在 wiki 上我读到 FireDac 可以使用多线程: http://docwiki.embarcadero.com/RADStudio/XE6/en/Multithreading_(FireDAC)
但是在 embarcadero 社区论坛 thread杰夫·奥弗卡什写道:
One thing I didn't see asked or Dmitry mention is you can not have TDataSource or LiveBindings against your background threaded queries. If you are background threading a query that displays the results you should disconnect the LB or DataSource, open and fetch all the data then re establish the connection.
Those two will be trying to move the cursor on you or querying the buffer for display while the buffer is very volatile being moved around in a different thread.
我想知道是否有人也使用 FireDac 并在表单上显示值可以帮助我。
最佳答案
下面的代码示例显示了从 MSSql 服务器检索记录的一种方法在使用 FireDAC 的后台线程中。这省略了一些细节。例如,在实践中,您可能希望线程的 Execute
包含一个 while 循环,在该循环中,它在调用 Synchronize
后等待信号量,然后关闭/重新打开查询以根据需要频繁更新主线程。
type
TForm1 = class;
TQueryThread = class(TThread)
private
FConnection: TFDConnection;
FQuery: TFDQuery;
FForm: TForm1;
published
constructor Create(AForm : TForm1);
destructor Destroy; override;
procedure Execute; override;
procedure TransferData;
property Query : TFDQuery read FQuery;
property Connection : TFDConnection read FConnection;
property Form : TForm1 read FForm;
end;
TForm1 = class(TForm)
FDConnection1: TFDConnection;
FDQuery1: TFDQuery;
DataSource1: TDataSource;
DBGrid1: TDBGrid;
DBNavigator1: TDBNavigator;
Button1: TButton;
procedure Button1Click(Sender: TObject);
procedure FormCreate(Sender: TObject);
public
QueryThread : TQueryThread;
end;
[...]
constructor TQueryThread.Create(AForm : TForm1);
begin
inherited Create(True);
FreeOnTerminate := True;
FForm := AForm;
FConnection := TFDConnection.Create(Nil);
FConnection.Params.Assign(Form.FDConnection1.Params);
FConnection.LoginPrompt := False;
FQuery := TFDQuery.Create(Nil);
FQuery.Connection := Connection;
FQuery.SQL.Text := Form.FDQuery1.SQL.Text;
end;
destructor TQueryThread.Destroy;
begin
FQuery.Free;
FConnection.Free;
inherited;
end;
procedure TQueryThread.Execute;
begin
Query.Open;
Synchronize(TransferData);
end;
procedure TQueryThread.TransferData;
begin
Form.FDQuery1.DisableControls;
Form.FDQuery1.Data := Query.Data;
Form.FDQuery1.EnableControls;
end;
procedure TForm1.Button1Click(Sender: TObject);
begin
QueryThread.Resume;
end;
procedure TForm1.FormCreate(Sender: TObject);
begin
QueryThread := TQueryThread.Create(Self);
end;
MJN 关于书签的评论告诉您如何在 gui 中保留当前数据行位置。
顺便说一句,虽然我经常使用 TClientDataSets 完成此操作,但将这个答案放在一起是我第一次使用 FireDAC 尝试。在配置组件方面,我所做的就是将组件从组件面板中拖出,按照您的预期将它们“连接在一起”,然后设置 FDConnection 的 Params 和 FDQuery 的 Sql。
关于delphi - FireDac 卡住 GUI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37830470/
在 Delphi Firedac 中,我有一个很长的查询。我想重用它只是通过这样的参数更改列的名称 select f1, f2 from t1 where id = :par1 and :colimn
我正在使用FireDAC的Array DML功能将大量数据插入到我的远程MS SQL数据库中。 它可以正常工作,但需要一些时间来完成执行方法。当执行方法运行时,我想知道FireDAC的内部进度,以便可
您好,我正在使用Firebird(2.5)作为数据库使用Firedac(Delphi Seattle),当我使用TFDQuery运行此查询时,未返回任何记录: SELECT ID FROM USERS
我创建了一个非常简单的控制台应用程序并尝试使用 Firedac 访问 Firebird 数据库。我正在尝试使用私有(private)定义设置来实现连接池,如下所述:http://docwiki.emb
我使用 Delphi XE7 和 FireDAC 来访问 SQLite。 当我将数据放入 TEXT 字段时,任何尾随空格或 #0 字符都会被截断。 我可以在 SQLite 或 FireDAC 中更改一
我正在开发一个在启动时带有登录表单的应用程序。 在用户写入登录数据之前,我想谨慎地连接到 SQL 服务器。 问题是,当我的服务器连接速度慢或路径错误时,应用程序正在寻找服务器或尝试连接,但此时应用程序
我目前正在开发一个多线程服务器应用程序,我计划使用 Firedac 进行数据访问。从此处提供的文档:http://docwiki.embarcadero.com/RADStudio/Tokyo/en/
我主要在后台线程中使用FireDAC,偶尔在主GUI线程中使用。 根据文档,有4种可能的执行模式,在我看来,只有2种是合适的: amBlocking The calling thread and GU
我正在尝试使用 FireDac 查询数据库。这是我的代码; procedure TfSMSViewer.LoadSMSFromDatabase(path: AnsiString); var con
我在 MS SQL Server 上创建了以下存储过程 CREATE PROCEDURE sppl_ParamTest @ID int = 666 AS BEGIN SELECT @ID;
我将 FireDac 与 Oracle 12c 数据库和 Delphi Seattle 结合使用。 我有一张员工表 EmployeeID - NUMBER GENERATED ALWAYS AS ID
我使用的是这里的示例: establishing connection 这样做: procedure TDataModule2.DataModuleCreate(Sender: TObject); b
我正在尝试用 Firedac MemoryTables 替换 Delphi ClientDatasets,它运行良好,但在处理大数据时速度非常慢我在数据模块中创建 FireDac 内存表并从表单填充它
我无法使用以下指令更新数据库中的行: fdquery1.Edit; fdquery1.fieldByName('prova').AsString := 'asdasd'; fdquery1.Open
我正在将 XE6 与 FireDac 一起使用。我有一个 FDMemTable,其中 ItemVals 作为 ftfloat 字段。我想使用 SUM(ItemVals) 的聚合函数,但我只想添加值 >
如何使用 FireDac 组件检查 DBMS 是否支持事务? 通常,我使用类似以下代码的内容,使用 dbExpress 在我的 DAO 类中执行事务。 ... connection: TSQLConn
我正在 Delphi 10.1 Berlin 下使用 FireDac。 为了向用户显示数据,我使用 TDBEdit 等数据感知控件。 我使用 TFDQuery 和 TDataSource 将它们与控件
我正在尝试使用 FireDAC 中的宏来预处理我的 SQL 查询。我在数据模块上有一个 TADQuery 对象,其 SQL 设置如下: Select * from MyTable join Oth
我想将一个非空非自动递增整数作为我的主键,但我无法在设计时使用 Firedac 来做到这一点。 TIntegerfield 没有任何参数可以让我将其设为主要参数。 TFDTable 也没有参数,我可以
我在 Firebird 数据库中定义了这个存储过程: create or alter procedure GET_MSG ( IDLNG smallint, IDMSG integer
我是一名优秀的程序员,十分优秀!