Qt中的嵌入式数据库

时间:2010-11-23 08:58:22

标签: c++ qt sqlite embedded-resource

我的Qt应用程序有一个SQLite数据库。我假设将数据库添加为资源是合乎逻辑的。

我无法使用嵌入式资源编译我的应用程序。

connection.h

#ifndef CONNECTION_H
#define CONNECTION_H

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

static bool createConnection()
{
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName(":/data/ShippingData.db3");
    if (!db.open())
    {
        QMessageBox::critical(0, QObject::tr("Database Error"), db.lastError().text());
        return false;
    }
    return true;
}

#endif // CONNECTION_H

assets.qrc

<RCC>
    <qresource prefix="/data">
        <file>ShippingData.db3</file>
    </qresource>
</RCC>

我的sqlite数据库现在就像这样

  app.pro
  file.h
  file.cpp
  data/ShippingData.db3

构建问题(来自Qt Creator)

No rule to make target `../TimePlotter/Shipping.db3', needed by `debug/qrc_assets.cpp'. Stop.

我尝试更改资源布局,因为它来自编译器不会进入数据库所在的数据/文件夹的消息。我得到了与此资源文件完全相同的构建问题

<RCC>
    <qresource>
        <file>data/ShippingData.db3</file>
    </qresource>
</RCC>

TimePlotter.pro

#-------------------------------------------------
#
# Project created by QtCreator 2010-11-21T03:18:17
#
#-------------------------------------------------

QT       += core gui

TARGET = TimePlotter
TEMPLATE = app


SOURCES += main.cpp\
        mainwindow.cpp \
    time.cpp \
    clients.cpp \
    printTime.cpp

HEADERS  += mainwindow.h \
    time.h \
    clients.h \
    printTime.h \
    connection.h

FORMS    += mainwindow.ui \
    time.ui \
    clients.ui \
    printTime.ui

RESOURCES += \
    assets.qrc

3 个答案:

答案 0 :(得分:11)

即使您解决了编译问题,在qrc文件中嵌入sqlite数据库也行不通。参见例如Qt Centre ForumQt-interest mailing list中的讨论。最好的解决方案是IMHO在qrc文件中包含数据库转储,创建内存sqlite db并从资源中的SQL语句重建数据库。

答案 1 :(得分:1)

您似乎删除或重命名了您的db文件Shipping.db3并添加了ShippingData.db3。要修复此构建问题,您应该删除构建文件夹并重建项目。这应该可以解决您的构建问题。

您可以在此处阅读的数据库部署说明:http://discussion.forum.nokia.com/forum/showthread.php?202894-Add-existing-Sqlite-database-to-Qt-project

答案 2 :(得分:1)

我至少知道如何在Mac OSX上执行此操作,其中QMAKE_BUNDLE_DATA参数有效。对于Windows,请查看this answer

  1. 在项目目录中创建一个名为“data”的目录。
  2. 将数据库文件放在那里。
  3. 在.pro文件中,添加以下部分:

    mac { Resources.files = data Resources.path = Contents/MacOS QMAKE_BUNDLE_DATA += Resources }

  4. 现在,当您重建应用程序时,它将位于Contents / MacOS / data文件夹中。因此,如果您的数据库名为custom.db:

    ,您可以执行类似的操作
    db.setDatabaseName(QCoreApplication::applicationDirPath().append("/data/custom.db"));