QSqlTableModel - 过滤器不工作?

时间:2015-11-28 23:09:23

标签: qt qsqltablemodel

我创建了一个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中可见的那些值的总和?

感谢您的回答!

1 个答案:

答案 0 :(得分:0)

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

model->setFilter(filter);

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

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