gpt4 book ai didi

c++ - 在 QtConcurrent::run 中使用 QSqlDatabase 连接(伪连接池)

转载 作者:太空狗 更新时间:2023-10-29 23:08:53 24 4
gpt4 key购买 nike

我正试图找到一种有效的方法来处理 Qt 中的某些数据库查询。该场景本质上是我们有许多事件需要写入数据库。我们不能在写入时阻塞主线程,因此这些写入是使用 QtConcurrent::run 在单独的线程中完成的。

现在的问题是,目前每个并发运行都需要创建一个新的数据库连接。我们希望能够简单地创建一次连接并重用它,但是 Qt 文档声明连接只能在创建它的线程中使用。使用 QtConcurrent 会带来很大的问题,因为我们不知道我们将在哪个线程中运行。

请注意,我们对并行写入数据库没有兴趣,也就是说,我们可以施加一次只有一个线程使用数据库连接的限制。

有没有办法在使用一个数据库连接的同时仍然使用 QtConcurrent?还是像我担心的那样,我们必须使用 QThread 并实现我们自己的信号而不是使用并发框架?


答案:正如我所怀疑的那样,答案似乎表明这是不可能完成的。 QtConcurrent 和 DB 连接不能很好地协同工作。这实在是太糟糕了。我想我会回去创建我自己的线程并使用自定义信号和插槽进行通信。

最佳答案

这篇文章对我帮助很大Asynchronous Database Access with Qt 4.x .我认为在线程中构建一个工作对象并使用排队连接调用它的槽,比驱动新事件并将它们发布到线程要好。您可以从 this link. 下载示例文件。

关于c++ - 在 QtConcurrent::run 中使用 QSqlDatabase 连接(伪连接池),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7785766/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com