Empty_Android 2017-12-01 07:12 采纳率: 70.6%
浏览 3742

qt Sqlite Driver not loaded.

写了一个SqliteHelper的demo.
打开,关闭和查询三个函数
运行之后提示找不到驱动的错误
图片说明

源码如下:
qt控制台程序
main.cpp

 #include <QCoreApplication>
#include <sqlitehelper.h>
#include <QDebug>

void SqliteDatabaseTest();

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);


    SqliteDatabaseTest();

    return a.exec();
}

void SqliteDatabaseTest()
{
    qDebug() << QSqlDatabase::drivers();

    SqliteHelper *sql_helper = new SqliteHelper();
    sql_helper->openDatabase();

    QString sql_command = "insert into ANPRInfo valuses(1,'民航A12345', 'D:\')";
    sql_helper->executeQuery(sql_command);

    sql_helper->closeDatabase();
    delete sql_helper;
}

sqlitehelper.h

 #ifndef SQLITEHELPER_H
#define SQLITEHELPER_H

#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>


class SqliteHelper
{
public:
    SqliteHelper();

    QSqlDatabase database;
    QSqlQuery sql_query;

    void openDatabase();
    void closeDatabase();
    void executeQuery(QString sql_command);
};

#endif // SQLITEHELPER_H

sqlitehelper.cpp

 #include "sqlitehelper.h"
#include <QDebug>

SqliteHelper::SqliteHelper()
{
    if (QSqlDatabase::contains("qt_sql_default_connection"))
    {
        database = QSqlDatabase::database("qt_sql_default_connection");
    }
    else
    {
        database = QSqlDatabase::addDatabase("QSQLITE");
        database.setDatabaseName("ANPRResults.sqlite");
        //database.setUserName("seenboom");
        //database.setPassword("seenboom");
    }
}

void SqliteHelper::openDatabase()
{
    if (!database.open())
    {
        qDebug() << "Error: Failed to connect database." << database.lastError();
    }
    else
    {
        // do something
    }
}

void SqliteHelper::closeDatabase()
{
    database.close();
}

void SqliteHelper::executeQuery(QString sql_command)
{
    if(!sql_query.exec())
    {
        qDebug() << sql_query.lastError();
    }
    else
    {

    }
}

.pro里面加入了 st += sql
是哪里的问题呢,请指教

  • 写回答

1条回答 默认 最新

  • Empty_Android 2017-12-01 09:32
    关注

    将sqlitehelper.h 中的 SqlQuery sql_query 写到cpp executeQuery函数中解决。

    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog