现在,我重新实现了 QSqlQueryModel 以使其可编辑,这意味着我重新实现了函数 QSqlQueryModel::setData() 和函数 QSqlQueryModel::flags() 并且我使用 QTableview 来显示数据。
在重新实现的函数 QSqlQueryModel::setData() 的最后,有一个刷新步骤再次将数据填充到模型中:
bool ScoreModel::setData(const QModelIndex &index, const QVariant &value, int /* role */)
{
if (index.column() == 0 || index.column() == 11)
return false;
QModelIndex primaryKeyIndex = QSqlQueryModel::index(index.row(), 0);
int id = data(primaryKeyIndex).toInt();
qDebug()<<"id:"<<id;
clear();
bool ok;
switch(index.column()){
case 1:
ok = setYear(id,value.toString());
break;
case 2:
ok = setStudentName(id,value.toString());
break;
...
case 10:
ok = setTeacherRemark(id,value.toString());
break;
default:
ok = false;
}
refresh();// <---
return ok;
}
void ScoreModel::refresh()
{
qDebug()<<"sqlToQueryScore in refresh:"<<MainWindow::sqlToQueryScore;
setQuery(MainWindow::sqlToQueryScore);
setHeaderData(0, Qt::Horizontal, tr("序号"));
setHeaderData(1, Qt::Horizontal, tr("年份"));
...
setHeaderData(11, Qt::Horizontal, tr("数据插入时间"));
}
但我在 mainwindow.cpp 中用以下代码装饰了 tableView(可以引用 ui->tableView):
ui->tableView->setModel(scoreModel);
//ui->tableView->setEditTriggers(QAbstractItemView::DoubleClicked);
ui->tableView->verticalHeader()->hide();
ui->tableView->resizeColumnsToContents();
ui->tableView->resizeRowsToContents();
//ui->tableView->setSelectionMode(QAbstractItemView::SingleSelection);
ui->tableView->setSelectionBehavior(QAbstractItemView::SelectRows);
ui->tableView->horizontalHeader()->setStretchLastSection(true);
为了保持tableView外观的一致性,我也想在刷新步骤中进行这样的操作。
在我有限的 Qt/C++ 经验中,我无法有效地处理它。我在网上找了很久。但是没有用。请帮助或尝试给出一些想法如何实现这一点。谢谢!