首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过Qt / QSqlTableModel (C++)轮询QSqlTableModel数据库

通过Qt / QSqlTableModel (C++)轮询QSqlTableModel数据库
EN

Stack Overflow用户
提问于 2010-12-20 20:31:47
回答 1查看 1.1K关注 0票数 1

我使用Qt连接到MySQL数据库(通过QSqlTableModel / QSqlDatabase / etc),尽管这个问题更为普遍。

获得“实时更新数据库表视图”的最佳方法是什么?一种选择是不断轮询整个表(在QSqlTableModel中反复调用select()方法)。但这似乎效率低下(整个表是否每次都从MySQL传递到Qt?)

另一个选项是有另一个表,它充当日志表(跟踪所有更新/更改),然后您可以轮询这个日志表(只检查新的entries..which似乎更有效?)。但是,您会丢失许多内置于功能中的QSql。

或者我应该有一个计数器变量,我投票,然后如果增加,我知道刷新整个表?

所有这些方法似乎有点混乱..。你有什么推荐的?谢谢。

EN

回答 1

Stack Overflow用户

发布于 2010-12-29 18:26:33

这确实是一个MySQL问题,但我有答案!:)

实际上,您想要的是每X秒轮询一次数据库。但是,如果您设置了一个MySQL“触发器”,那么如果插入、更新和/或删除了一行,它就会创建一个指示符。

我认为您应该创建一个触发器,将修改后的行插入第二个表中。Qt程序的民意测验应该执行以下操作:

  • 锁定第二个“修改”表
  • 读取第二个“修改”表
  • 的全部内容,删除第二个“修改”表
  • 的所有内容,解锁第二个“修改”表

<代码>F29

如果不锁定表,则可能会意外删除在读取和删除之间插入的一个新行。但是,如果您希望/需要避免锁定,只需读取所有内容,然后根据每一行插入到“修改”表中生成的唯一ID删除所检索的行。

MySQL触发器的常见问题和文档如下:http://dev.mysql.com/doc/refman/5.0/en/faqs-triggers.html

锁定/解锁表的文档如下:http://dev.mysql.com/doc/refman/5.0/en/lock-tables.html

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4493654

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档