我创建了一个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中可见的那些值的总和?
感谢您的回答!
答案 0 :(得分:0)
model = new QSqlTableModel;
model->setTable("XXX");
model->setFilter(filter);
*model->select();//select after set filter*
table = new QTableView;
table->setModel(model);