25 #include <QSqlDatabase>
29 #include <QSqlTableModel>
34 #include "src/classes/paths.h"
36 #include "src/database/row.h"
51 #define DB OPL::Database::instance()
65 const QFileInfo databaseFile;
66 QStringList tableNames;
67 QHash<QString, QStringList> tableColumns;
69 inline const static QString SQLITE_DRIVER = QStringLiteral(
"QSQLITE");
70 inline const static QList<OPL::DbTable> USER_TABLES = {
71 OPL::DbTable::Flights,
75 inline const static QList<OPL::DbTable> TEMPLATE_TABLES = {
76 OPL::DbTable::Aircraft,
77 OPL::DbTable::Airports,
78 OPL::DbTable::Currencies,
79 OPL::DbTable::Changelog,
85 void operator=(
const Database&) =
delete;
146 QVector<QVariant>
customQuery(QString statement,
int return_values);
208 const auto data =
getRowData(OPL::DbTable::Pilots, row_id);
217 const auto data =
getRowData(OPL::DbTable::Tails, row_id);
226 const auto data =
getRowData(OPL::DbTable::Aircraft, row_id);
235 const auto data =
getRowData(OPL::DbTable::Flights, row_id);
244 const auto data =
getRowData(OPL::DbTable::Simulators, row_id);
253 const auto data =
getRowData(OPL::DbTable::Currencies, row_id);
262 const auto data =
getRowData(OPL::DbTable::Airports, row_id);
A Row representing an Aircraft entry. See Row class for details.
Definition: row.h:85
A Row representing an Airport entry. See Row class for details.
Definition: row.h:155
A Row representing a Currency entry. See Row class for details.
Definition: row.h:144
The DB class encapsulates the SQL database by providing fast access to hot database data.
Definition: database.h:57
const QString sqliteVersion() const
Database::sqliteVersion returns the database sqlite version. See also dbRevision()
Definition: database.cpp:117
bool connect()
Connect to the database and populate database information.
Definition: database.cpp:26
static QSqlDatabase database()
Can be used to access the database connection.
Definition: database.cpp:126
OPL::PilotEntry getPilotEntry(int row_id)
retreives a PilotEntry from the database. See row class for details.
Definition: database.h:206
bool remove(const OPL::Row &row)
deletes an entry from the database.
Definition: database.cpp:186
RowData_T getRowData(const OPL::DbTable table, const int row_id)
retreive a Map of <column name, column content> for a specific row in the database.
Definition: database.cpp:427
bool createBackup(const QString &dest_file)
Database::createBackup copies the currently used database to an external backup location provided by ...
Definition: database.cpp:582
bool update(const OPL::Row &updated_row)
Updates entry in database from existing entry tweaked by the user.
Definition: database.cpp:303
bool importTemplateData(bool use_local_ressources)
importTemplateData fills an empty database with the template data (Aircraft, Airports,...
Definition: database.cpp:666
QList< int > getForeignKeyConstraints(int foreign_row_id, OPL::DbTable table)
returns a list of ROWID's in the flights table for which foreign key constraints exist.
Definition: database.cpp:472
void updateLayout()
Updates the member variables tableNames and tableColumns with up-to-date layout information if the da...
Definition: database.cpp:92
OPL::FlightEntry getFlightEntry(int row_id)
retreives a flight entry from the database. See row class for details.
Definition: database.h:233
OPL::AirportEntry getAirportEntry(int row_id)
Retreives an airport entry from the database. See row class for details.
Definition: database.h:260
bool resetUserData()
Delete all rows from the user data tables (flights, pliots, tails)
Definition: database.cpp:706
bool exists(const OPL::Row &row)
Checks if an entry exists in the database, based on position data.
Definition: database.cpp:259
bool removeMany(OPL::DbTable table, const QList< int > &row_id_list)
deletes a batch of entries from the database. Optimised for speed when deleting many entries....
Definition: database.cpp:217
const QString version() const
Return the database revision number (not the sqlite version number).
Definition: database.cpp:65
bool restoreBackup(const QString &backup_file)
Database::restoreBackup restores the database from a given backup file and replaces the currently act...
Definition: database.cpp:600
QVector< RowData_T > getTable(OPL::DbTable table)
getTable returns all contents of a given table from the database
Definition: database.cpp:537
OPL::AircraftEntry getAircraftEntry(int row_id)
retreives a TailEntry from the database. See row class for details.
Definition: database.h:224
void dataBaseUpdated(const DbTable table)
updated is emitted whenever the database contents have been updated. This can be either a commit,...
bool createSchema()
Create or restore the database to its ready-to-use but empty state.
Definition: database.cpp:631
OPL::TailEntry getTailEntry(int row_id)
retreives a TailEntry from the database. See row class for details.
Definition: database.h:215
const QStringList getTableNames() const
Return the names of all tables in the database.
Definition: database.cpp:87
OPL::SimulatorEntry getSimEntry(int row_id)
retreives a Simulator entry from the database. See row class for details.
Definition: database.h:242
bool clear()
clear resets the database, i.e. deletes all content in the tables containing userdata (pilots,...
Definition: database.cpp:288
bool insert(const OPL::Row &new_row)
Create new entry in the databse based on UserInput.
Definition: database.cpp:346
QSqlError lastError
Holds information about the last error that ocurred during a SQL operation. If the error type is QSql...
Definition: database.h:96
QVector< QVariant > customQuery(QString statement, int return_values)
Can be used to send a complex query to the database.
Definition: database.cpp:509
const QList< OPL::DbTable > & getUserTables() const
getUserTables returns a list of the of the tables that contain user-created data (flights,...
Definition: database.cpp:77
const QStringList getTableColumns(OPL::DbTable table_name) const
Return the names of a given table in the database.
Definition: database.cpp:82
void connectionReset()
connectionReset is emitted whenever the database connection is reset, for example when creating or re...
void disconnect()
closes the database connection.
Definition: database.cpp:53
const QList< OPL::DbTable > & getTemplateTables() const
getTemplateTables returns a list of the tables that contain template data (aiports,...
Definition: database.cpp:72
bool commit(const OPL::Row &row)
commits an entry to the database, calls either insert or update, based on position data
Definition: database.cpp:131
OPL::Row getRow(const OPL::DbTable table, const int row_id)
retreive a Row from the database
Definition: database.cpp:395
int getLastEntry(OPL::DbTable table)
returns the ROWID for the newest entry in the respective table.
Definition: database.cpp:459
OPL::CurrencyEntry getCurrencyEntry(int row_id)
Retreives a currency entry from the database. See row class for details.
Definition: database.h:251
A Row representing a Flight entry. See Row class for details.
Definition: row.h:133
static const QFileInfo databaseFileInfo()
returns a QFileInfo for the default database file.
Definition: paths.cpp:39
A Row representing a Pilot entry. See Row class for details.
Definition: row.h:110
The Row class provides an interface for retreiving and submitting entries from the database.
Definition: row.h:46
A Row representing a Simulator entry. See Row class for details.
Definition: row.h:122
A Row representing a Tail (Registration) entry. See Row class for details.
Definition: row.h:96
A namespace to collect constants and enums used throughout the application.
Definition: paths.cpp:3
DbTable
Enumerates the tables in the database.
Definition: opl.h:122