gpt4 book ai didi

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

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:37:15 26 4
gpt4 key购买 nike

我有一个使用 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/

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