В моем проекте три файла .cpp:

Теперь я переопределил 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("数据插入时间"));
}
но я украсил tableView следующим кодом в mainwindow.cpp (где можно ссылаться на 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 ++ я не могу не справиться с этим эффективно.Я давно ищу в сети.Но бесполезно.Пожалуйста, помогите или попробуйте дать некоторые идеи, как этого добиться. Спасибо!