我有一个使用 QSqlTableModel
的 QTableView
。
在底层数据库(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/