query/src/sql/session.cpp

111 lines
2.8 KiB
C++

#include "matador/sql/session.hpp"
#include "matador/sql/backend_provider.hpp"
#include <stdexcept>
namespace matador::sql {
session::session(connection_pool<connection> &pool)
: pool_(pool)
, dialect_(backend_provider::instance().connection_dialect(pool_.info().type))
, schema_(std::make_unique<sql::schema>(dialect_.default_schema_name())){}
void session::create_schema()
{
auto c = pool_.acquire();
for (const auto &t : *schema_) {
c->query(*schema_).create().table(t.second.name, t.second.prototype.columns()).execute();
}
}
void session::drop_table(const std::string &table_name)
{
auto c = pool_.acquire();
if (!c.valid()) {
throw std::logic_error("no database connection available");
}
c->query(*schema_).drop().table(table_name).execute();
}
query_result<record> session::fetch(const query_context &q) const
{
auto c = pool_.acquire();
if (!c.valid()) {
throw std::logic_error("no database connection available");
}
auto it = prototypes_.find(q.table.name);
if (it == prototypes_.end()) {
it = prototypes_.emplace(q.table.name, c->describe(q.table.name)).first;
}
// adjust columns from given query
for (auto &col : q.prototype) {
if (const auto rit = it->second.find(col.name()); col.type() == data_type_t::type_unknown && rit != it->second.end()) {
const_cast<column_definition&>(col).type(rit->type());
}
}
auto res = c->fetch(q.sql);
return query_result<record>{std::move(res), q.prototype};
}
//query_result<record> session::fetch(const std::string &sql) const
//{
// return query_result<record>(std::unique_ptr());
//}
size_t session::execute(const std::string &sql) const {
auto c = pool_.acquire();
if (!c.valid()) {
throw std::logic_error("no database connection available");
}
return c->execute(sql);
}
statement session::prepare(query_context q) const
{
auto c = pool_.acquire();
if (!c.valid()) {
throw std::logic_error("no database connection available");
}
return c->prepare(std::move(q));
}
std::vector<sql::column_definition> session::describe_table(const std::string &table_name) const
{
auto c = pool_.acquire();
if (!c.valid()) {
throw std::logic_error("no database connection available");
}
return c->describe(table_name);
}
bool session::table_exists(const std::string &table_name) const
{
auto c = pool_.acquire();
if (!c.valid()) {
throw std::logic_error("no database connection available");
}
return c->exists(dialect_.default_schema_name(), table_name);
}
const schema& session::tables() const
{
return *schema_;
}
const class dialect &session::dialect() const
{
return dialect_;
}
std::unique_ptr<query_result_impl> session::fetch(const std::string &sql) const
{
auto c = pool_.acquire();
if (!c.valid()) {
throw std::logic_error("no database connection available");
}
return c->fetch(sql);
}
}