0

代码说得更好:

model = new QSqlRelationalTableModel();
model->setEditStrategy(QSqlRelationalTableModel::OnRowChange);
model->setTable("members");
model->setRelation(Member_TeamID, QSqlRelation("teams", "ID", "Name"));
model->setSort(Member_Name, Qt::AscendingOrder);
model->select();

mapper = new QDataWidgetMapper();
mapper->setSubmitPolicy(QDataWidgetMapper::ManualSubmit);
mapper->setModel(model);
mapper->setItemDelegate(new QSqlRelationalDelegate());

void member_detail::deleteMember()

{
    int row = mapper->currentIndex();
    bool x=    model->removeRow(row);
    mapper->submit();
    mapper->setCurrentIndex(qMin(row, model->rowCount() - 1)); 
    QMessageBox::critical(0,"W",QString::number(x)); // This Echos false 

}

简单地说,当我调用 deleteMember 时,记录并没有从模型中删除,而是从数据库中删除(我使用 Navicat 对其进行检查)规格:Qt 5.0.2 Linux 64-bit,g++ 作为编译器

4

1 回答 1

0

来自QSqlTableModel::removeRows文档:

在删除行之前发出 beforeDelete() 信号。当编辑策略为 OnManualSubmit 时,信号发射会延迟到 submitAll() 被调用。

因此,请检查您正在使用的编辑策略并尝试model->submitAll()在更改后调用。

于 2013-06-20T14:58:46.200 回答