1

在我的应用程序中,我使用 QSqlDatabase 来存储一些信息。我确实使用以下命令成功构建了它(即使使用 也没有错误verbose=3):

macdeployqt AppName.app/ -dmg -qmldir=~/dev/AppName/qml

在此之前我使用端口成功安装了 mysql55

sudo port install mysql55

如果我尝试运行我的应用程序,它不会崩溃,但它也不会做任何涉及数据库访问的事情。

这是我打开数据库等的代码:

#include <QSqlQuery>
#include <QSqlDriver>

const QString DATABASE_NAME = "com.company.program.db";

MyClass::MyClass(QObject *parent) : QObject(parent) {
    mDB = QSqlDatabase::addDatabase("QSQLITE");

    #ifdef Q_OS_LINUX
    QString path(QDir::home().path());
    path.append(QDir::separator()).append(DATABASE_NAME);
    path = QDir::toNativeSeparators(path);
    mDB.setDatabaseName(path);           // NOTE: We have to store database file into user home folder in Linux
    #else
    mDB.setDatabaseName(DATABASE_NAME);  // NOTE: File exists in the application private folder, in Symbian Qt implementation
    #endif

    bool notOpened = !mDB.open();

    QMessageBox::critical(0, "MyClass", mDB.lastError().databaseText()); // always is 'out of memory'

    if (notOpened) emit failedToOpen();
    else {
        // some initialization
    }
}

MyClass::~MyClass() {
    mDB.close();
}

有没有人遇到过同样的问题/解决这个问题?

注意:我使用的是 Mac OS X 10.9 和 Qt5.3.2

4

2 回答 2

0

数据库驱动程序在运行时加载。如果 db-driver 路径不正确,则在编译过程中不会出现任何与数据库配置相关的错误。当您在安装了 Qt 的机器上构建时,路径甚至不能不正确。

在 Windows 上,当 exe 无法访问 plugins\sqldrivers 中的文件时,经常会发生这种情况。MAC上有类似Linux的'strace'吗?如果是,您可以跟踪您的 exe 尝试在哪些路径中查找驱动程序插件。

我总是在安装程序中复制整个插件目录并将其部署在可执行文件的根目录中,例如 C:\Program Files (x86)\\plugins

希望能帮助到你。

于 2014-10-02T12:07:32.517 回答
0

我设法out of memory通过执行以下代码来修复错误:

#ifdef Q_OS_MAC
    QString databaseName = QApplication::applicationDirPath().append("/").append(DATABASE_NAME);
    mDB.setDatabaseName(databaseName);
#endif
于 2014-10-06T11:01:10.447 回答