问题描述
我有一个复杂的软件,其中包含多个表格和表格。 我需要在 QsqlQueryModel 中加入一些表并将结果显示到 QTableView 我使用 QSortFilterProxyModel 能够在包含结果的 QTableView 中进行搜索 当我创建 QTableView 并设置模型时,一切正常,但是当在软件的另一部分数据库发生变化时,我看不到 QTableView 中的数据变化。
这是一段代码:
void form1::setModels()
{
queryModel = new QsqlQueryModel();
queryModel->setQuery("SELECT * FROM table1");
proxyModel = new QSortFilterProxyModel(queryModel);
proxyModel->setSourceModel(queryModel);
ui->tableView->setModel(proxyModel);
}
这个方法是在我创建form1的时候调用的,放在数据库连接和open()调用下面
在我用 exec 调用 form1 之前,我尝试做一个:(form1 包含提到的 QTableView)
queryModel->query().exec()
就像模型中间的东西没有正确更新
如果我在表单 exec 方法之前调用 setModels()(不仅在表单的构造函数中),QTableView 会正确显示更改,但我认为这不是进行更新的正确方法,我已经有了模型,还有tableview,我想我只需要更新查询和刷新QTableView和QSortFilterProxyModel,但我没有找到这样做的方法。
解决方法
但是当在软件的另一部分数据库发生变化时,我看不到 QTableView 中的数据变化。
您需要更新模型,然后视图将收到任何更改的通知。当您更改表 table1
时,您对该模型进行了重置(重置模型,然后查询数据库)。