0

我创建了一个 QSqlTableModel,设置了一个过滤器并使用 QTableView 来显示我过滤数据的表格。这按预期工作......

model = new QSqlTableModel;
model->setTable("XXX");
model->select();

model->setFilter(filter);

table = new QTableView;
table->setModel(model);

但是,当我尝试计算表视图中列的所有可见值的总和时......

float sum = 0.0f;
for(int i=0;i<model->rowCount();i++)
    sum += model->record(i).value("amount").toFloat();

...我得到表模型中所有条目的总和,而不仅仅是 TableView 中可见的那些项目(应用过滤器的地方)。

如何使我的 sum() 函数仅计算 TableView 中可见的那些值的总和?

谢谢您的回答!

4

1 回答 1

0
model = new QSqlTableModel;
model->setTable("XXX");

model->setFilter(filter);

*model->select();//select after set filter*

table = new QTableView;
table->setModel(model);
于 2016-09-30T03:23:54.493 回答