unique sql database connection is created on different threads

Signed-off-by: Paulchen-Panther <Paulchen-Panter@protonmail.com>
This commit is contained in:
Paulchen-Panther 2019-07-16 23:11:53 +02:00
parent 90599e820a
commit c676b640f1
No known key found for this signature in database
GPG Key ID: 84E3B692456B6840
3 changed files with 15 additions and 25 deletions

View File

@ -32,7 +32,7 @@ public:
/// set root path /// set root path
void setRootPath(const QString& rootPath); void setRootPath(const QString& rootPath);
/// define the database to work with /// define the database to work with
void setDB(const QString& dbn); void setDatabaseName(const QString& dbn) { _dbn = dbn; };
/// set a table to work with /// set a table to work with
void setTable(const QString& table); void setTable(const QString& table);

View File

@ -19,7 +19,7 @@ public:
{ {
// Init Hyperion database usage // Init Hyperion database usage
setRootPath(rootPath); setRootPath(rootPath);
setDB("hyperion"); setDatabaseName("hyperion");
// Init instance table // Init instance table
setTable("instances"); setTable("instances");

View File

@ -4,10 +4,13 @@
#include <QSqlError> #include <QSqlError>
#include <QSqlQuery> #include <QSqlQuery>
#include <QSqlRecord> #include <QSqlRecord>
#include <QThreadStorage>
#include <QUuid>
#include <QDir> #include <QDir>
// not in header because of linking // not in header because of linking
static QString _rootPath; static QString _rootPath;
static QThreadStorage<QSqlDatabase> _databasePool;
DBManager::DBManager(QObject* parent) DBManager::DBManager(QObject* parent)
: QObject(parent) : QObject(parent)
@ -26,22 +29,6 @@ void DBManager::setRootPath(const QString& rootPath)
QDir().mkpath(_rootPath+"/db"); QDir().mkpath(_rootPath+"/db");
} }
void DBManager::setDB(const QString& dbn)
{
_dbn = dbn;
// new database connection if not found
if(!QSqlDatabase::contains(dbn))
{
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE",dbn);
db.setDatabaseName(_rootPath+"/db/"+dbn+".db");
if(!db.open())
{
Error(_log, QSTRING_CSTR(db.lastError().text()));
throw std::runtime_error("Failed to open database connection!");
}
}
}
void DBManager::setTable(const QString& table) void DBManager::setTable(const QString& table)
{ {
_table = table; _table = table;
@ -49,18 +36,21 @@ void DBManager::setTable(const QString& table)
QSqlDatabase DBManager::getDB() const QSqlDatabase DBManager::getDB() const
{ {
QSqlDatabase db = QSqlDatabase::database(_dbn); if(_databasePool.hasLocalData())
return _databasePool.localData();
if (db.isOpen() && db.isValid())
return db;
else else
{ {
db = QSqlDatabase::addDatabase("QSQLITE", _dbn); auto db = QSqlDatabase::addDatabase("QSQLITE", QUuid::createUuid().toString());
_databasePool.setLocalData(db);
db.setDatabaseName(_rootPath+"/db/"+_dbn+".db"); db.setDatabaseName(_rootPath+"/db/"+_dbn+".db");
if(!db.open())
{
Error(_log, QSTRING_CSTR(db.lastError().text()));
throw std::runtime_error("Failed to open database connection!");
} }
return db; return db;
} }
}
bool DBManager::createRecord(const VectorPair& conditions, const QVariantMap& columns) const bool DBManager::createRecord(const VectorPair& conditions, const QVariantMap& columns) const
{ {