我的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
答案 0 :(得分:11)
即使您解决了编译问题,在qrc文件中嵌入sqlite数据库也行不通。参见例如Qt Centre Forum或Qt-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。
在.pro文件中,添加以下部分:
mac {
Resources.files = data
Resources.path = Contents/MacOS
QMAKE_BUNDLE_DATA += Resources
}
现在,当您重建应用程序时,它将位于Contents / MacOS / data文件夹中。因此,如果您的数据库名为custom.db:
,您可以执行类似的操作db.setDatabaseName(QCoreApplication::applicationDirPath().append("/data/custom.db"));