fixing postgres tests progress

This commit is contained in:
sascha 2026-04-24 16:56:44 +02:00
parent 3a82f4891a
commit 656d045ccf
7 changed files with 32 additions and 30 deletions

View File

@ -95,14 +95,14 @@ utils::result<object::object_ptr<Type>, utils::error> session::insert(object::ob
} }
// Build dependency-ordered insert steps (deps first, root last) // Build dependency-ordered insert steps (deps first, root last)
query::insert_query_builder<Type> iqb(schema_, contexts_by_type_); insert_query_builder<Type> iqb(schema_, contexts_by_type_);
auto steps = iqb.build(obj); auto steps = iqb.build(obj);
if (!steps.is_ok()) { if (!steps.is_ok()) {
return utils::failure(make_error(error_code::FailedToBuildQuery, "Failed to build insert dependency queries.")); return utils::failure(make_error(error_code::FailedToBuildQuery, "Failed to build insert dependency queries."));
} }
// Execute all steps; for Identity steps read RETURNING and write pk back into the object // Execute all steps; for Identity steps read RETURNING and write pk back into the object
for (query::insert_step &step : *steps) { for (insert_step &step : *steps) {
if (step.pk_generator == utils::generator_type::Sequence || step.pk_generator == utils::generator_type::Table) { if (step.pk_generator == utils::generator_type::Sequence || step.pk_generator == utils::generator_type::Table) {
const auto conn = pool_.acquire(); const auto conn = pool_.acquire();
if (!conn.valid()) { if (!conn.valid()) {

View File

@ -43,13 +43,11 @@ public:
[[nodiscard]] bool is_relation_table() const; [[nodiscard]] bool is_relation_table() const;
[[nodiscard]] bool has_primary_key() const; [[nodiscard]] bool has_primary_key() const;
[[nodiscard]] std::optional<table_column*> primary_key_column() const; [[nodiscard]] const table_column* primary_key_column() const;
[[nodiscard]] const std::string& join_column_name() const; [[nodiscard]] const std::string& join_column_name() const;
[[nodiscard]] const std::string& inverse_join_column_name() const; [[nodiscard]] const std::string& inverse_join_column_name() const;
protected: protected:
// static const table_column& create_column(class table& tab, const std::string& name);
table(std::string name, std::string alias, const std::vector<table_column>& columns); table(std::string name, std::string alias, const std::vector<table_column>& columns);
private: private:
@ -61,7 +59,7 @@ private:
std::string schema_name_; std::string schema_name_;
std::vector<table_column> columns_; std::vector<table_column> columns_;
std::optional<table_column*> pk_column_{std::nullopt}; int pk_column_index_{-1};
std::string join_column_name_; std::string join_column_name_;
std::string inverse_join_column_name_; std::string inverse_join_column_name_;
}; };

View File

@ -42,19 +42,19 @@ session::session(session_context&& ctx, const query::schema &scm)
// SELECT one // SELECT one
queries.select_one = query::select(node.table()) queries.select_one = query::select(node.table())
.from(node.name()) .from(node.name())
.where(*node.table().primary_key_column().value() == _) .where(*node.table().primary_key_column() == _)
.compile(dialect_); .compile(dialect_);
// UPDATE one // UPDATE one
auto update_set = query::update(node.table()); auto update_set = query::update(node.table());
for (const auto &col: node.table().columns()) { for (const auto &col: node.table().columns()) {
update_set.set(col, _); update_set.set(col, _);
} }
queries.update_one = update_set.where(*node.table().primary_key_column().value() == _) queries.update_one = update_set.where(*node.table().primary_key_column() == _)
.compile(dialect_); .compile(dialect_);
// DELETE one // DELETE one
queries.delete_one = query::remove() queries.delete_one = query::remove()
.from(node.name()) .from(node.name())
.where(*node.table().primary_key_column().value() == _) .where(*node.table().primary_key_column() == _)
.compile(dialect_); .compile(dialect_);
} }
// INSERT one // INSERT one
@ -63,6 +63,11 @@ session::session(session_context&& ctx, const query::schema &scm)
.values(query::generator::placeholders(node.table().columns().size())) .values(query::generator::placeholders(node.table().columns().size()))
.compile(dialect_); .compile(dialect_);
queries.insert.resolver = resolver_service_;
queries.update_one.resolver = resolver_service_;
queries.delete_one.resolver = resolver_service_;
queries.select_one.resolver = resolver_service_;
queries.select_all.resolver = resolver_service_;
contexts_by_type_[node.node().type_index()] = queries; contexts_by_type_[node.node().type_index()] = queries;
} }

View File

@ -19,16 +19,20 @@ table::table(std::string name, std::string alias, const std::vector<table_column
: name_(std::move(name)) : name_(std::move(name))
, alias_(std::move(alias)) , alias_(std::move(alias))
, columns_(columns) { , columns_(columns) {
for (auto &col : columns_) { for (int i = 0; i < columns.size(); ++i) {
col.table(this); columns_[i].table(this);
if (col.is_primary_key()) { if (columns_[i].is_primary_key()) {
pk_column_ = &col; pk_column_index_ = i;
} }
} }
} }
table::table(const table &other) table::table(const table &other)
: table(other.name_, other.alias_, other.columns_) { : name_(other.name_)
, alias_(other.alias_)
, schema_name_(other.schema_name_)
, columns_(other.columns_)
, pk_column_index_(other.pk_column_index_){
for (auto &col : columns_) { for (auto &col : columns_) {
col.table(this); col.table(this);
} }
@ -49,6 +53,7 @@ table & table::operator=(table &&other) noexcept {
name_ = std::move(other.name_); name_ = std::move(other.name_);
alias_ = std::move(other.alias_); alias_ = std::move(other.alias_);
columns_ = std::move(other.columns_); columns_ = std::move(other.columns_);
pk_column_index_ = other.pk_column_index_;
for (auto &col : columns_) { for (auto &col : columns_) {
col.table(this); col.table(this);
} }
@ -109,11 +114,11 @@ bool table::is_relation_table() const {
} }
bool table::has_primary_key() const { bool table::has_primary_key() const {
return pk_column_.has_value(); return pk_column_index_ > -1;
} }
std::optional<table_column *> table::primary_key_column() const { const table_column* table::primary_key_column() const {
return pk_column_; return pk_column_index_ > -1 ? &columns_.at(pk_column_index_) : nullptr;
} }
const std::string &table::join_column_name() const { const std::string &table::join_column_name() const {
@ -123,10 +128,4 @@ const std::string &table::join_column_name() const {
const std::string &table::inverse_join_column_name() const { const std::string &table::inverse_join_column_name() const {
return inverse_join_column_name_; return inverse_join_column_name_;
} }
// const table_column& table::create_column(class table &tab, const std::string &name) {
// tab.columns_.emplace_back(name);
// tab.columns_.back().table(&tab);
// return tab.columns_.back();
// }
} }

View File

@ -139,19 +139,19 @@ bool table_column::is_nullable() const {
} }
bool table_column::is_primary_key() const { bool table_column::is_primary_key() const {
return !utils::is_constraint_set(attributes_.options(), utils::constraints::PrimaryKey); return utils::is_constraint_set(attributes_.options(), utils::constraints::PrimaryKey);
} }
bool table_column::is_foreign_key() const { bool table_column::is_foreign_key() const {
return !utils::is_constraint_set(attributes_.options(), utils::constraints::ForeignKey); return utils::is_constraint_set(attributes_.options(), utils::constraints::ForeignKey);
} }
bool table_column::is_unique() const { bool table_column::is_unique() const {
return !utils::is_constraint_set(attributes_.options(), utils::constraints::Unique); return utils::is_constraint_set(attributes_.options(), utils::constraints::Unique);
} }
bool table_column::is_identity() const { bool table_column::is_identity() const {
return !utils::is_constraint_set(attributes_.options(), utils::constraints::Identity); return utils::is_constraint_set(attributes_.options(), utils::constraints::Identity);
} }
sql::sql_function_t table_column::function() const { sql::sql_function_t table_column::function() const {

View File

@ -24,8 +24,8 @@ struct airplane {
namespace field = matador::access; namespace field = matador::access;
using namespace matador::utils; using namespace matador::utils;
field::primary_key(op, "id", id); field::primary_key(op, "id", id);
field::attribute(op, "brand", brand, UniqueVarChar255); field::attribute(op, "brand", brand, VarChar255);
field::attribute(op, "model", model, UniqueVarChar255); field::attribute(op, "model", model, VarChar255);
} }
}; };
} }

View File

@ -29,7 +29,7 @@ struct flight {
namespace field = matador::access; namespace field = matador::access;
using namespace matador::utils; using namespace matador::utils;
field::primary_key(op, "id", id); field::primary_key(op, "id", id);
field::belongs_to(op, "airplane_id", plane, {utils::cascade_type::All, fetch_type::Eager}); field::belongs_to(op, "airplane_id", plane, CascadeAllFetchEager);
field::attribute(op, "pilot_name", pilot_name, VarChar255); field::attribute(op, "pilot_name", pilot_name, VarChar255);
} }
}; };