/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of Qt Creator. ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3 as published by the Free Software ** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-3.0.html. ** ****************************************************************************/ #pragma once #include "sqlitedatabasebackend.h" #include "sqliteglobal.h" #include "sqlitetable.h" #include "sqlitetransaction.h" #include #include #include #include namespace Sqlite { using namespace std::chrono_literals; class ReadStatement; class WriteStatement; class SQLITE_EXPORT Database final : public TransactionInterface { template friend class Statement; friend class Backend; public: using MutexType = std::mutex; using ReadStatement = Sqlite::ReadStatement; using WriteStatement = Sqlite::WriteStatement; Database(); Database(Utils::PathString &&databaseFilePath, JournalMode journalMode=JournalMode::Wal); Database(Utils::PathString &&databaseFilePath, std::chrono::milliseconds busyTimeout = 1000ms, JournalMode journalMode=JournalMode::Wal); ~Database(); Database(const Database &) = delete; Database &operator=(const Database &) = delete; void open(); void open(Utils::PathString &&databaseFilePath); void close(); bool isOpen() const; Table &addTable(); const std::vector &tables() const; void setDatabaseFilePath(Utils::PathString &&databaseFilePath); const Utils::PathString &databaseFilePath() const; void setJournalMode(JournalMode journalMode); JournalMode journalMode() const; void setOpenMode(OpenMode openMode); OpenMode openMode() const; void execute(Utils::SmallStringView sqlStatement); DatabaseBackend &backend(); int64_t lastInsertedRowId() const { return m_databaseBackend.lastInsertedRowId(); } void setLastInsertedRowId(int64_t rowId) { m_databaseBackend.setLastInsertedRowId(rowId); } int changesCount() { return m_databaseBackend.changesCount(); } int totalChangesCount() { return m_databaseBackend.totalChangesCount(); } private: void deferredBegin(); void immediateBegin(); void exclusiveBegin(); void commit(); void rollback(); void lock(); void unlock(); void initializeTables(); void registerTransactionStatements(); void deleteTransactionStatements(); std::mutex &databaseMutex() { return m_databaseMutex; } class Statements; private: Utils::PathString m_databaseFilePath; DatabaseBackend m_databaseBackend; std::vector
m_sqliteTables; std::mutex m_databaseMutex; std::unique_ptr m_statements; std::chrono::milliseconds m_busyTimeout; JournalMode m_journalMode = JournalMode::Wal; OpenMode m_openMode = OpenMode::ReadWrite; bool m_isOpen = false; }; } // namespace Sqlite