【发布时间】:2015-07-09 17:04:52
【问题描述】:
我对 QSqlTableModel 进行了子类化,并重写了 data() 和 setData() 来进行单位转换。也就是说,我想在进入 db 时将值乘以用户指定的乘数,并在 UI 中显示该字段时除以相同的乘数。但是,由于某种原因,除了最初填充字段外,不会调用 setData()。
结果:每次我在 UI 中单击一个字段时,data() 中的转换都会完成并除以值,而无需先在 setData() 中相乘。一遍又一遍地点击该字段,该字段最终达到零值。
如果调用 setData() 会有什么影响?
当我查看到达我的 data() 的堆栈跟踪时,似乎 QSqlTableModel::setData 每次都被调用,而不是我的函数。每次调用 setData 时我都会提交()更改,所以这不应该是问题。
github 存储库中的代码现在已修复,可以按照解决方案按预期工作。 完整代码:https://github.com/savolai/qsqltablemodel_conversion_example
主窗口.cpp:
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
// connect to db
QSqlDatabase db;
db = QSqlDatabase::addDatabase("QSQLITE", "db");
db.setDatabaseName("db.sqlite");
if (!db.open()) {
QMessageBox::critical(0, "Opening database failed",
"Opening database failed. It really did.", QMessageBox::Close);
}
// connect model to db table table1
TableModel *model=new TableModel(this,db);
model->setTable("table1");
model->setEditStrategy(QSqlTableModel::OnFieldChange);
model->select();
// add new record
QSqlRecord record;
QSqlField field0("radio", QVariant::Int);
field0.setValue(QVariant(QVariant::Int));
int fieldnumber=0;
record.insert(fieldnumber,field0);
int id=-1;
QSqlError error;
if(model->insertRecord(model->rowCount(),record)){
if(model->submitAll()){
id=record.value("id").toInt();
}else{
error=model->lastError();
qDebug()<<error.text();
}
}else{
error=model->lastError();
qDebug()<<error.text();
}
QDataWidgetMapper* mapper = new QDataWidgetMapper(this);
mapper->setModel(model);
mapper->toLast();
mapper->addMapping(ui->lineEdit,model->fieldIndex("text"));
}
tablemodel.cpp:
TableModel::TableModel(QObject *parent, QSqlDatabase db)
: QSqlTableModel(parent,db)
{
}
bool TableModel::setData(const QModelIndex &index, QVariant &value, int role){
double dValue=value.toDouble();
double baseValue=dValue*2;
bool success=QSqlTableModel::setData(index,QVariant(baseValue),role);
emit dataChanged(index,index);
return success;
}
QVariant TableModel::data(const QModelIndex &index, int role) const
{
QVariant value=QSqlTableModel::data(index,role);
double dValue=value.toDouble();
double userValue=dValue/2;
return QVariant(userValue);
}
【问题讨论】:
-
你能给我们看一些代码吗?
-
当然!做了一个简化的例子来展示这种行为。除法完成,乘法没有。
标签: c++ qt sqlite model-view-controller