设置了 QSortFilterProxyModel 的 QTableView 基于 QSqlQueryModel 不会在数据库中的数据更改时更新

问题描述

我有一个复杂的软件,其中包含多个表格和表格。 我需要在 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 时,您对该模型进行了重置(重置模型,然后查询数据库)。