首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >处理QSqlDatabase连接

处理QSqlDatabase连接
EN

Stack Overflow用户
提问于 2014-08-25 09:48:00
回答 3查看 9.2K关注 0票数 4

处理QSqlDatabase连接的正确方法是什么?

在我的节目中,我是这样做的:

代码语言:javascript
复制
DatabaseConnector *databaseConnector = 0;
try
{
    databaseConnector = new DatabaseConnector();
    //Do stuff...
    delete databaseConnector;
}
catch(QString e)
{
    delete databaseConnector;
    QMessageBox::information(this,"Error",e);
}

databaseConnector.h

代码语言:javascript
复制
#ifndef DATABASECONNECTOR_H
#define DATABASECONNECTOR_H
#include <QtSql>

class DatabaseConnector
{
public:
    DatabaseConnector();
    DatabaseConnector(QString hostname, QString database, QString user, QString password);
    ~DatabaseConnector();
private:
    QSqlDatabase db;
};

#endif // DATABASECONNECTOR_H

databaseconnector.cpp

代码语言:javascript
复制
#include "databaseconnector.h"
#include <QString>

DatabaseConnector::DatabaseConnector()
{
    QSettings settings;

    db = QSqlDatabase::addDatabase("QIBASE");
    db.setHostName(settings.value("db/host").toString());
    db.setDatabaseName(settings.value("db/name").toString());
    db.setUserName(settings.value("db/user").toString());
    db.setPassword(settings.value("db/pass").toString());

    if(!db.open())
    {
        QString databaseConnectionError = db.lastError().text();
        throw databaseConnectionError;
    }
}

DatabaseConnector::DatabaseConnector(QString hostname, QString database, QString user,     QString password)
{
    db = QSqlDatabase::addDatabase("QIBASE");
    db.setHostName(hostname);
    db.setDatabaseName(database);
    db.setUserName(user);
    db.setPassword(password);
    if(!db.open())
    {
        QString databaseConnectionError = db.lastError().text();
        throw databaseConnectionError;
    }

}

DatabaseConnector::~DatabaseConnector()
{
    db.close();
}

即使我使用QSqlDatabase::removeDatabase(db.connectionName());,我也会出错

QSqlDatabasePrivate::addDatabase:重复连接名称‘qt_sql_default’,删除旧连接。

EN

回答 3

Stack Overflow用户

发布于 2014-08-25 10:06:51

通常,您不需要在应用程序中多次打开数据库连接。

添加数据库时,可以将连接命名为:

代码语言:javascript
复制
QSqlDatabase::addDatabase( "QIBASE", "MyDBConnectionName" );

您可以使用名称查询连接:

代码语言:javascript
复制
if( QSqlDatabase::contains( "MyDBConnectionName" ) )
{
    QSqlDatabase db = QSqlDatabase::database( "MyDBConnectionName" );
    //Do stuff...
}
else
{
    // connection not found, do something
}

还请注意,在调用QSqlDatabase::removeDatabase之前,您应该断开数据库连接:

代码语言:javascript
复制
db.close();
QSqlDatabase::removeDatabase("MyDBConnectionName");
票数 6
EN

Stack Overflow用户

发布于 2014-08-25 10:07:49

为了添加一个新的数据库,您需要给它命名。如果没有给出唯一的名称,默认的数据库将被重用.这在类引用中有记录。

尝试:

代码语言:javascript
复制
db = QSqlDatabase::addDatabase("QIBASE", databaseName);
票数 0
EN

Stack Overflow用户

发布于 2016-08-10 07:20:39

在主程序中:

代码语言:javascript
复制
QSqlDatabase db =QSqlDatabase::addDatabase( "QSQLITE");

在第二个应用程序中:

代码语言:javascript
复制
QSqlDatabase db2 =QSqlDatabase::database();
票数 -2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25483218

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档