Qt查询执行错误

时间:2012-03-26 05:05:57

标签: qt qtsql

bool    MainWindow::initDb() {
    db = QSqlDatabase::addDatabase("QSQLITE"); // defined on class header as QSqldatabase db
    db.setDatabaseName("data.db");
    if (!db.open()) {
        QMessageBox::critical(this,
                              tr("Error"),
                              tr("Could not save data. Database problem."));
        return false;
    }
    query.prepare("create table if not exists snippet (id int primary key, title varchar(255) not null, tags varchar(255), snippet text)");
    if (!query.exec()) { // error
        QMessageBox::critical(this,
                              tr("Database error"),
                              tr("Could not setup database"));
        qDebug() << "Database error : " << query.lastError();
        return false;
    }
    query.clear();
    return true;
}

数据库它在控制台中显示数据库错误消息框和以下内容。

Database error :  QSqlError(-1, "Driver not loaded", "Driver not loaded") 

1 个答案:

答案 0 :(得分:1)

我得到了部分解决方案。将查询作为本地对象并将 db 传递给它的构造函数来解决问题。 像

QSqlQuery query(db);