diff options
author | louiz’ <louiz@louiz.org> | 2017-10-04 21:28:18 +0200 |
---|---|---|
committer | louiz’ <louiz@louiz.org> | 2017-12-02 20:08:47 +0100 |
commit | 0168b96b79db2627fdba77a8712956408aa081d1 (patch) | |
tree | 5591527ed8a04be8ea04c49521d9e9c868677bd1 /src/database/sqlite3_engine.hpp | |
parent | 5b27cee97272d4ae6ff30f03dc57221fa3e3183f (diff) | |
download | biboumi-0168b96b79db2627fdba77a8712956408aa081d1.tar.gz biboumi-0168b96b79db2627fdba77a8712956408aa081d1.tar.bz2 biboumi-0168b96b79db2627fdba77a8712956408aa081d1.tar.xz biboumi-0168b96b79db2627fdba77a8712956408aa081d1.zip |
Add postgresql support
Diffstat (limited to 'src/database/sqlite3_engine.hpp')
-rw-r--r-- | src/database/sqlite3_engine.hpp | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/database/sqlite3_engine.hpp b/src/database/sqlite3_engine.hpp new file mode 100644 index 0000000..eb18d0c --- /dev/null +++ b/src/database/sqlite3_engine.hpp @@ -0,0 +1,30 @@ +#pragma once + +#include <database/engine.hpp> + +#include <database/statement.hpp> + +#include <sqlite3.h> +#include <memory> +#include <string> +#include <tuple> +#include <set> + +class Sqlite3Engine: public DatabaseEngine +{ + public: + Sqlite3Engine(sqlite3* db); + + ~Sqlite3Engine(); + + static std::unique_ptr<DatabaseEngine> open(const std::string& string); + + std::set<std::string> get_all_columns_from_table(const std::string& table_name) override final; + std::tuple<bool, std::string> raw_exec(const std::string& query) override final; + std::unique_ptr<Statement> prepare(const std::string& query) override; + void extract_last_insert_rowid(Statement& statement) override; + std::string id_column_type() override; +private: + sqlite3* const db; +}; + |