123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- // qCTKDCMTK includes
- #include "qCTKDCMTK.h"
- // Qt includes
- #include <QDebug>
- #include <QSqlDatabase>
- #include <QSqlError>
- #include <QSqlQuery>
- #include <QFile>
- #include <QStringList>
- #include <iostream>
- //----------------------------------------------------------------------------
- class qCTKDCMTKPrivate: public qCTKPrivate<qCTKDCMTK>
- {
- public:
- qCTKDCMTKPrivate();
- bool executeScript(const QString& script);
- QSqlDatabase Database;
- QString DatabaseFileName;
- QString LastError;
- };
- //----------------------------------------------------------------------------
- // qCTKDCMTKPrivate methods
- qCTKDCMTKPrivate::qCTKDCMTKPrivate()
- {
- }
- //----------------------------------------------------------------------------
- // qCTKDCMTKWidget methods
- qCTKDCMTK::qCTKDCMTK(QObject* _parent): Superclass(_parent)
- {
- QCTK_INIT_PRIVATE(qCTKDCMTK);
- }
- //----------------------------------------------------------------------------
- qCTKDCMTK::~qCTKDCMTK()
- {
- }
- //----------------------------------------------------------------------------
- bool qCTKDCMTK::openDatabase(const QString& databaseFileName)
- {
- QCTK_D(qCTKDCMTK);
- d->Database = QSqlDatabase::addDatabase("QSQLITE","DICOM-DB");
- d->Database.setDatabaseName(databaseFileName);
- if ( ! (d->Database.open()) )
- {
- d->LastError = d->Database.lastError().text();
- return false;
- }
- if ( d->Database.tables().empty() )
- {
- initializeDatabase();
- }
- return true;
- }
- const QString& qCTKDCMTK::GetLastError() const {
- QCTK_D(const qCTKDCMTK);
- return d->LastError;
- }
- const QSqlDatabase& qCTKDCMTK::database() const {
- QCTK_D(const qCTKDCMTK);
- return d->Database;
- }
- bool qCTKDCMTKPrivate::executeScript(const QString& script) {
- QFile scriptFile(script);
- scriptFile.open(QIODevice::ReadOnly);
- if ( !scriptFile.isOpen() )
- {
- qDebug() << "Script file " << script << " could not be opened!\n";
- return false;
- }
- QString sqlCommands( QTextStream(&scriptFile).readAll() );
- sqlCommands.replace( '\n', ' ' );
- sqlCommands.replace("; ", ";\n");
- QStringList sqlCommandsLines = sqlCommands.split('\n');
- QSqlQuery query(Database);
- for (QStringList::iterator it = sqlCommandsLines.begin(); it != sqlCommandsLines.end()-1; ++it)
- {
- if (! (*it).startsWith("--") )
- {
- query.exec(*it);
- if (query.lastError().type())
- {
- qDebug() << "There was an error during execution of the statement: " << (*it);
- qDebug() << "Error message: " << query.lastError().text();
- return false;
- }
- }
- }
- return true;
- }
- bool qCTKDCMTK::initializeDatabase(const char* sqlFileName)
- {
- QCTK_D(qCTKDCMTK);
- return d->executeScript(sqlFileName);
- }
-
- void qCTKDCMTK::closeDatabase()
- {
- QCTK_D(qCTKDCMTK);
- d->Database.close();
- }
|