c++ - 如何有效地选择符合特定条件的 QTableView 行的子集?

标签 c++ qt qt4 model-view-controller

我有一个使用 QSqlTableModelQTableView

在底层数据库(postgresql)表中有一个时间戳列。

如何选择选择模型中基础时间戳列为 NULL 的所有行?

指向正确方向的指针会有所帮助。

更新:

我一直遇到的主要问题是性能。我尝试过的每种方法都会导致两个性能问题。

首先是对 selectionModel()->select(selection) 的调用需要 30 秒才能选择大约 5,000 条记录。它似乎正在为每一行发出选择更改信号。即使信号处理程序被禁用,它仍然需要 10 秒。

第二个性能问题是,即使在使用所选行更新 View 之后,尝试 ScrollView 也非常缓慢且滞后。我的猜测是选择模型由 5,000 个单独的选择组成,而不仅仅是最小数量的选择范围。

在我正在试验的数据中,选择是连续的;所以它应该能够表示为一个单一的选择范围。如果我简单地调用 tableView->selectAll(),那么这非常快。

我想知道是否有一种规范、有效的方法来选择一组匹配的行。或者我的代码中可能存在导致性能下降的缺陷。有没有办法按照 count0 的建议使用 QSortFilterProxyModel完成这个?我希望 View 显示所有行,但选择了匹配的行。

这是我尝试的最后一种方法的代码片段:

void MainWindow::selectNullTimestamp()
{

    QModelIndex start = model->index(0, TIMESTAMP_COLUMN);


    QModelIndexList indexes = model
                ->match(start, Qt::DisplayRole,
            QVariant(QString("")),
            -1,
            Qt::MatchFixedString);

    QItemSelectionModel* selection_model = ui->tableView->selectionModel();

    QItemSelection selection;

    foreach(QModelIndex index, indexes) {

        QModelIndex left =
            model->index(index.row(), 0);

        QModelIndex right =
            model->index(index.row(),
                                 NUM_COLUMNS - 1);

        QItemSelection sel(left, right);

        selection.merge(sel, QItemSelectionModel::Select);

    }

    selection_model->select(selection, QItemSelectionModel::Select);

}

最佳答案

可能为时已晚,但它总能提供帮助! 我遇到了这个问题,我认为使用 QItemSelection 可以有效地解决问题

示例:

假设您的 TableView 名为 myTableView 并且您想要选择偶数行 [0, 2, 4, 6, ...]

myTableView->clearSelection();
QItemSelection selection;
for (int i = 0 ; i < myTableView->rowCount(); i += 1)
{
    QModelIndex leftIndex  = myTableView->model()->index(i, 0);
    QModelIndex rightIndex = myTableView->model()->index(i, myTableView->columnCount() -1);

    QItemSelection rowSelection(leftIndex, rightIndex);
    selection.merge(rowSelection, QItemSelectionModel::Select);
}
myTableView->selectionModel()->select(selection, QItemSelectionModel::Select);

关于c++ - 如何有效地选择符合特定条件的 QTableView 行的子集?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1369494/

相关文章:

c++ - 如何在发出 commandFinished() 信号时检查状态

c++ - 简单的文档切换器功能?

c++ - 轻量级 C++ 脚本库

qt - 在第二台显示器上启动程序(Qt 框架)

c++ - 对 C++11 标准的工具链支持

c++ - 如何在枚举中保留前导零?

c++ - 在函数声明之后声明一个整数有什么用?

c++ - 在使用来自站点的已编译代码构建库时,我无法解决 C++ 中的错误 (LNK2001)

windows - 关于 Qt Shadow Build for Ubuntu 或 Win

qt - 我的代码哪里出错了?