delete many to many progress

This commit is contained in:
sascha 2026-06-01 16:44:07 +02:00
parent cea7b97f2b
commit 12f8590634
6 changed files with 38 additions and 11 deletions

View File

@ -105,6 +105,7 @@ public:
void on_foreign_key(const char *id, Pointer &/*x*/) { void on_foreign_key(const char *id, Pointer &/*x*/) {
const auto type = pk_type_determinator::determine<typename Pointer::value_type>(); const auto type = pk_type_determinator::determine<typename Pointer::value_type>();
auto &ref = object_->attributes_.emplace_back(id, type, utils::constraints::ForeignKey, null_option_type::NotNull); auto &ref = object_->attributes_.emplace_back(id, type, utils::constraints::ForeignKey, null_option_type::NotNull);
ref.index_ = object_->attributes_.size() - 1;
ref.owner_ = object_; ref.owner_ = object_;
} }
template<class ContainerType> template<class ContainerType>

View File

@ -373,7 +373,9 @@ void schema_observer<Type>::on_attach(const object::repository_node &node, const
auto producer = std::make_unique<query_object_resolver_producer<Type>>(schema_, it->second.table(), it->second.node().info().primary_key_attribute()->name()); auto producer = std::make_unique<query_object_resolver_producer<Type>>(schema_, it->second.table(), it->second.node().info().primary_key_attribute()->name());
schema_.resolver_producers_[typeid(Type)] = std::move(producer); schema_.resolver_producers_[typeid(Type)] = std::move(producer);
} else { } else {
object::join_columns_collector collector; const auto it = schema_.insert_relation_table(typeid(Type), node);
// auto producer = std::make_unique<query_object_resolver_producer<Type>>(schema_, it->second.table(), it->second.node().info().primary_key_attribute()->name());
// schema_.resolver_producers_[typeid(Type)] = std::move(producer);
} }
} }

View File

@ -17,6 +17,7 @@ public:
table(const char *name); // NOLINT(*-explicit-constructor) table(const char *name); // NOLINT(*-explicit-constructor)
table(const std::string& name); // NOLINT(*-explicit-constructor) table(const std::string& name); // NOLINT(*-explicit-constructor)
table(const std::string& name, const std::vector<table_column>& columns); table(const std::string& name, const std::vector<table_column>& columns);
table(const std::string& name, const std::vector<table_column>& columns, const std::string& join_column, const std::string& inverse_join_column);
table(const table& other); table(const table& other);
table& operator=(const table& other); table& operator=(const table& other);
table(table&& other) noexcept; table(table&& other) noexcept;
@ -44,11 +45,11 @@ public:
[[nodiscard]] bool has_primary_key() const; [[nodiscard]] bool has_primary_key() const;
[[nodiscard]] const table_column* primary_key_column() const; [[nodiscard]] const table_column* primary_key_column() const;
[[nodiscard]] const std::string& join_column_name() const; [[nodiscard]] const table_column* join_column() const;
[[nodiscard]] const std::string& inverse_join_column_name() const; [[nodiscard]] const table_column* inverse_join_column() const;
protected: protected:
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:
friend table_column; friend table_column;
@ -60,8 +61,8 @@ private:
std::vector<table_column> columns_; std::vector<table_column> columns_;
int pk_column_index_{-1}; int pk_column_index_{-1};
std::string join_column_name_; int join_column_index_{-1};
std::string inverse_join_column_name_; int inverse_join_column_index_{-1};
}; };
template<typename Type = table> template<typename Type = table>

View File

@ -61,5 +61,17 @@ schema::iterator schema::insert_table(const std::type_index &ti, const object::r
} }
basic_schema::iterator schema::insert_relation_table(const std::type_index &ti, const object::repository_node &node) { basic_schema::iterator schema::insert_relation_table(const std::type_index &ti, const object::repository_node &node) {
std::vector<table_column> columns;
const auto* attr = node.info().object()->join_attribute();
if (attr == nullptr) {
return schema_nodes_.end();
}
columns.emplace_back(nullptr, attr->name(), attr->type(), attr->attributes());
attr = node.info().object()->inverse_join_attribute();
if (attr == nullptr) {
return schema_nodes_.end();
}
columns.emplace_back(nullptr, attr->name(), attr->type(), attr->attributes());
return schema_nodes_.insert({ti, schema_node{table(node.name(), columns, node.info().object()->join_attribute()->name(), node.info().object()->inverse_join_attribute()->name()), nullptr, node}}).first;
} }
} // namespace matador::query } // namespace matador::query

View File

@ -30,6 +30,11 @@ query_contexts to_query_contexts(const schema_node& node, const sql::dialect &d)
.from(node.name()) .from(node.name())
.where(*node.table().primary_key_column() == _) .where(*node.table().primary_key_column() == _)
.compile(d); .compile(d);
} else {
queries.delete_one = query::remove()
.from(node.name())
.where(*node.table().join_column() == _ && *node.table().inverse_join_column() == _)
.compile(d);
} }
// INSERT one // INSERT one
std::vector<table_column> columns; std::vector<table_column> columns;
@ -39,7 +44,7 @@ query_contexts to_query_contexts(const schema_node& node, const sql::dialect &d)
} }
columns.push_back(col); columns.push_back(col);
} }
if (node.pk_generator().type() == utils::generator_type::Identity) { if (node.table().has_primary_key() && node.pk_generator().type() == generator_type::Identity) {
queries.insert = query::insert() queries.insert = query::insert()
.into(node.name(), columns) .into(node.name(), columns)
.values(generator::placeholders(columns.size())) .values(generator::placeholders(columns.size()))

View File

@ -15,6 +15,12 @@ table::table(const std::string& name, const std::vector<table_column> &columns)
: table(name, name, columns) { : table(name, name, columns) {
} }
table::table(const std::string& name, const std::vector<table_column>& columns, const std::string& join_column, const std::string& inverse_join_column)
: table(name, name, columns)
, join_column_index_(column_by_name(*this, join_column))
, inverse_join_column_index_(column_by_name(*this, inverse_join_column)){
}
table::table(std::string name, std::string alias, const std::vector<table_column> &columns) table::table(std::string name, std::string alias, const std::vector<table_column> &columns)
: name_(std::move(name)) : name_(std::move(name))
, alias_(std::move(alias)) , alias_(std::move(alias))
@ -121,11 +127,11 @@ const table_column* table::primary_key_column() const {
return pk_column_index_ > -1 ? &columns_.at(pk_column_index_) : nullptr; return pk_column_index_ > -1 ? &columns_.at(pk_column_index_) : nullptr;
} }
const std::string &table::join_column_name() const { const table_column* table::join_column() const {
return join_column_name_; return join_column_index_ > -1 ? &columns_.at(join_column_index_) : nullptr;
} }
const std::string &table::inverse_join_column_name() const { const table_column* table::inverse_join_column() const {
return inverse_join_column_name_; return inverse_join_column_index_ > -1 ? &columns_.at(inverse_join_column_index_) : nullptr;
} }
} }