gpt4 book ai didi

c++ - Qt 4 Sqlite,QDataWidgetMapper 问题

转载 作者:行者123 更新时间:2023-11-30 03:08:24 25 4
gpt4 key购买 nike

我正在编写一个 Symbian 小应用程序,但在使用 QDataWidgetMapper 时遇到了问题。这是代码:

void Widget::bindToData(){
databaseManager = new DatabaseManager();
dataMapper = new QDataWidgetMapper();
dataMapper->setSubmitPolicy(QDataWidgetMapper::AutoSubmit);
dataMapper->setModel(databaseManager->getTableModel());
dataMapper->addMapping(ui->debugLabel, databaseManager->getTableModel()->fieldIndex("item")); //ko
QSqlQuery q;
bool ret = q.exec("SELECT * FROM expense");

if (!ret){
databaseManager->showDebugMsg(q.lastError().text());
}
while (q.next()) {
QString item = q.value(1).toString();
databaseManager->showDebugMsg(item); //ok
}

dataMapper->toFirst();


}

在我用一些测试行填充数据库之前,我确信它有效,因为

databaseManager->showDebugMsg(item);

显示正确的数据。但是映射失败。 getTableModel 非常简单:

QSqlTableModel *  DatabaseManager::getTableModel(){
tableModel->select();
return tableModel;
}

这里是 DatabaseManager 的构造函数:

DatabaseManager::DatabaseManager(){
debugMsgBox = new QMessageBox();
this->deleteDB();
this->openDB();
this->createExpenseTable();
this->insertTestExpense("test", 11.0);
tableModel = new QSqlTableModel();
tableModel->setTable("expense");

}

由于 insertTestExspense 有效,我认为问题可能出在 setTable() 中......但我看不出我错过了什么......

有什么想法吗?

最佳答案

您可以做几件事来让它发挥作用:

1.检查 fieldIndex("item") 是否实际返回有效的字段索引。

2.对于QLabel映射也指定text数据管理器的 addMapping 调用的属性名称:

dataMapper->addMapping(ui->debugLabel, databaseManager->getTableModel()>fieldIndex("item"), "text");

希望这对你有帮助,问候

关于c++ - Qt 4 Sqlite,QDataWidgetMapper 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5030082/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com