renamed constraint to restriction

This commit is contained in:
Sascha Kühl 2025-12-09 14:53:29 +01:00
parent 4fcbe9c064
commit c4f8731262
23 changed files with 80 additions and 75 deletions

View File

@ -2,7 +2,7 @@
#define BASIC_PROTOTYPE_INFO_HPP #define BASIC_PROTOTYPE_INFO_HPP
#include "matador/object/attribute.hpp" #include "matador/object/attribute.hpp"
#include "matador/object/constraint.hpp" #include "matador/object/restriction.hpp"
#include "matador/object/relation_endpoint.hpp" #include "matador/object/relation_endpoint.hpp"
#include "matador/utils/identifier.hpp" #include "matador/utils/identifier.hpp"
@ -28,7 +28,7 @@ public:
[[nodiscard]] std::string name() const; [[nodiscard]] std::string name() const;
[[nodiscard]] std::shared_ptr<class object> object() const; [[nodiscard]] std::shared_ptr<class object> object() const;
[[nodiscard]] const std::list<attribute>& attributes() const; [[nodiscard]] const std::list<attribute>& attributes() const;
[[nodiscard]] const std::list<class constraint>& constraints() const; [[nodiscard]] const std::list<class restriction>& constraints() const;
[[nodiscard]] bool has_primary_key() const; [[nodiscard]] bool has_primary_key() const;
[[nodiscard]] const utils::identifier& primary_key() const; [[nodiscard]] const utils::identifier& primary_key() const;

View File

@ -1,7 +1,7 @@
#ifndef MATADOR_CONSTRAINTS_GENERATOR_HPP #ifndef MATADOR_CONSTRAINTS_GENERATOR_HPP
#define MATADOR_CONSTRAINTS_GENERATOR_HPP #define MATADOR_CONSTRAINTS_GENERATOR_HPP
#include "matador/object/constraint.hpp" #include "matador/object/restriction.hpp"
#include "matador/utils/access.hpp" #include "matador/utils/access.hpp"
#include "matador/utils/field_attributes.hpp" #include "matador/utils/field_attributes.hpp"
@ -17,20 +17,20 @@ class repository;
class constraints_generator final { class constraints_generator final {
private: private:
constraints_generator(std::list<class constraint> &constraints, const repository &repo, const std::shared_ptr<object> &obj); constraints_generator(std::list<class restriction> &constraints, const repository &repo, const std::shared_ptr<object> &obj);
public: public:
constraints_generator() = delete; constraints_generator() = delete;
template < typename Type > template < typename Type >
static std::list<class constraint> generate(const repository &repo, object &obj) { static std::list<class restriction> generate(const repository &repo, const std::shared_ptr<object> &obj) {
Type t; Type t;
return generate(t, repo, obj); return generate(t, repo, obj);
} }
template < typename Type > template < typename Type >
static std::list<class constraint> generate(const Type& t, const repository &repo, object &obj) { static std::list<class restriction> generate(const Type& t, const repository &repo, const std::shared_ptr<object> &obj) {
std::list<class constraint> constraints; std::list<class restriction> constraints;
constraints_generator gen(constraints, repo, obj); constraints_generator gen(constraints, repo, obj);
access::process(gen, t); access::process(gen, t);
return constraints; return constraints;
@ -69,7 +69,7 @@ private:
[[nodiscard]] std::list<attribute>::iterator find_attribute_by_name(const std::string &name) const; [[nodiscard]] std::list<attribute>::iterator find_attribute_by_name(const std::string &name) const;
private: private:
std::list<class constraint> &constraints_; std::list<class restriction> &constraints_;
const repository &repo_; const repository &repo_;
std::shared_ptr<object> obj_; std::shared_ptr<object> obj_;
}; };

View File

@ -2,7 +2,7 @@
#define MATADOR_OBJECT_HPP #define MATADOR_OBJECT_HPP
#include "matador/object/attribute.hpp" #include "matador/object/attribute.hpp"
#include "matador/object/constraint.hpp" #include "matador/object/restriction.hpp"
#include "matador/utils/identifier.hpp" #include "matador/utils/identifier.hpp"
@ -37,7 +37,7 @@ public:
[[nodiscard]] bool has_constraints() const; [[nodiscard]] bool has_constraints() const;
[[nodiscard]] size_t constraint_count() const; [[nodiscard]] size_t constraint_count() const;
[[nodiscard]] const std::list<class constraint>& constraints() const; [[nodiscard]] const std::list<class restriction>& constraints() const;
friend std::ostream& operator<<(std::ostream& os, const object& obj); friend std::ostream& operator<<(std::ostream& os, const object& obj);
@ -52,7 +52,7 @@ private:
attribute* pk_attribute_{nullptr}; attribute* pk_attribute_{nullptr};
utils::identifier pk_identifier_; utils::identifier pk_identifier_;
std::list<attribute> attributes_; std::list<attribute> attributes_;
std::list<class constraint> constraints_; std::list<class restriction> constraints_;
}; };
} }
#endif //MATADOR_OBJECT_HPP #endif //MATADOR_OBJECT_HPP

View File

@ -54,7 +54,7 @@ private:
public: public:
template < class Type > template < class Type >
static std::shared_ptr<object> generate(const repository &repo, const std::string &name, const std::string &alias = "") { static std::shared_ptr<object> generate(repository &repo, const std::string &name, const std::string &alias = "") {
return generate(std::make_unique<Type>(), repo, name, alias); return generate(std::make_unique<Type>(), repo, name, alias);
} }

View File

@ -15,10 +15,10 @@ class constraint_builder;
class constraint_generator; class constraint_generator;
class object; class object;
class constraint { class restriction {
public: public:
constraint() = default; restriction() = default;
explicit constraint(std::string name); explicit restriction(std::string name);
[[nodiscard]] const std::string& name() const; [[nodiscard]] const std::string& name() const;
[[nodiscard]] const class attribute* attribute() const; [[nodiscard]] const class attribute* attribute() const;
@ -30,7 +30,7 @@ public:
[[nodiscard]] const std::string& ref_table_name() const; [[nodiscard]] const std::string& ref_table_name() const;
[[nodiscard]] const std::string& ref_column_name() const; [[nodiscard]] const std::string& ref_column_name() const;
friend std::ostream& operator<<(std::ostream& os, const constraint& c); friend std::ostream& operator<<(std::ostream& os, const restriction& c);
private: private:
friend class constraint_builder; friend class constraint_builder;
@ -54,7 +54,7 @@ public:
constraint_builder& foreign_key(std::string name); constraint_builder& foreign_key(std::string name);
constraint_builder& references(std::string table, std::string column); constraint_builder& references(std::string table, std::string column);
operator class constraint() const; operator class restriction() const;
private: private:
std::string constraint_name; std::string constraint_name;

View File

@ -52,8 +52,8 @@ public:
[[nodiscard]] utils::result<bool, utils::error> table_exists(const std::string &table_name) const; [[nodiscard]] utils::result<bool, utils::error> table_exists(const std::string &table_name) const;
private: private:
sql::query_context build_add_constraint_context( const object::repository_node& node, const class object::constraint& cons ) const; sql::query_context build_add_constraint_context( const object::repository_node& node, const class object::restriction& cons ) const;
sql::query_context build_drop_constraint_context( const object::repository_node& node, const class object::constraint& cons ) const; sql::query_context build_drop_constraint_context( const object::repository_node& node, const class object::restriction& cons ) const;
private: private:
object::repository repo_; object::repository repo_;

View File

@ -145,7 +145,7 @@ private:
friend class query_select; friend class query_select;
static query::fetchable_query build_select_query(entity_query_data &&data); static query::fetchable_query build_select_query(entity_query_data &&data);
static sql::query_context build_add_constraint_context(const std::string& table_name, const class object::constraint& cons, const sql::connection_ptr &conn) ; static sql::query_context build_add_constraint_context(const std::string& table_name, const class object::restriction& cons, const sql::connection_ptr &conn) ;
private: private:
mutable sql::statement_cache cache_; mutable sql::statement_cache cache_;

View File

@ -64,9 +64,9 @@ using Boolean = typed_data_type<bool>;
using Varchar = sized_typed_data_type<std::string>; using Varchar = sized_typed_data_type<std::string>;
using Blob = sized_typed_data_type<std::vector<std::byte>>; using Blob = sized_typed_data_type<std::vector<std::byte>>;
class constraint { class restriction {
public: public:
explicit constraint(std::string name) explicit restriction(std::string name)
: name_(std::move(name)) {} : name_(std::move(name)) {}
[[nodiscard]] const std::string& name() const; [[nodiscard]] const std::string& name() const;
@ -126,7 +126,7 @@ public:
constraint_builder& references(std::string table, std::string column); constraint_builder& references(std::string table, std::string column);
// ReSharper disable once CppNonExplicitConversionOperator // ReSharper disable once CppNonExplicitConversionOperator
operator object::constraint() const; // NOLINT(*-explicit-constructor) operator object::restriction() const; // NOLINT(*-explicit-constructor)
private: private:
std::string constraint_name; std::string constraint_name;

View File

@ -2,7 +2,7 @@
#define MATADOR_QUERY_ALTER_TABLE_INTERMEDIATE_HPP #define MATADOR_QUERY_ALTER_TABLE_INTERMEDIATE_HPP
#include "executable_query.hpp" #include "executable_query.hpp"
#include "matador/object/constraint.hpp" #include "matador/object/restriction.hpp"
#include "matador/query/intermediates/query_intermediate.hpp" #include "matador/query/intermediates/query_intermediate.hpp"
namespace matador::query { namespace matador::query {

View File

@ -6,7 +6,7 @@
#include "matador/query/intermediates/executable_query.hpp" #include "matador/query/intermediates/executable_query.hpp"
#include "matador/object/attribute.hpp" #include "matador/object/attribute.hpp"
#include "matador/object/constraint.hpp" #include "matador/object/restriction.hpp"
#include <list> #include <list>
@ -16,8 +16,8 @@ class query_create_table_columns_intermediate : public executable_query {
public: public:
using executable_query::executable_query; using executable_query::executable_query;
executable_query constraints(std::initializer_list<class object::constraint> constraints); executable_query constraints(std::initializer_list<class object::restriction> constraints);
executable_query constraints(const std::list<class object::constraint> &constraints); executable_query constraints(const std::list<class object::restriction> &constraints);
}; };
class query_create_table_intermediate : public query_intermediate { class query_create_table_intermediate : public query_intermediate {

View File

@ -10,7 +10,7 @@
#include "matador/query/table.hpp" #include "matador/query/table.hpp"
#include "matador/object/attribute.hpp" #include "matador/object/attribute.hpp"
#include "matador/object/constraint.hpp" #include "matador/object/restriction.hpp"
#include "matador/utils/placeholder.hpp" #include "matador/utils/placeholder.hpp"
@ -392,15 +392,15 @@ private:
class query_create_table_constraints_part final : public query_part { class query_create_table_constraints_part final : public query_part {
public: public:
explicit query_create_table_constraints_part(const std::list<class object::constraint> &constraints); explicit query_create_table_constraints_part(const std::list<class object::restriction> &constraints);
[[nodiscard]] const std::list<class object::constraint>& constraints() const; [[nodiscard]] const std::list<class object::restriction>& constraints() const;
private: private:
void accept(query_part_visitor &visitor) override; void accept(query_part_visitor &visitor) override;
private: private:
std::list<class object::constraint> constraints_; std::list<class object::restriction> constraints_;
}; };
class query_create_schema_part final : public query_part { class query_create_schema_part final : public query_part {

View File

@ -16,13 +16,13 @@ add_library(matador-core STATIC
../../include/matador/object/attribute.hpp ../../include/matador/object/attribute.hpp
../../include/matador/object/attribute_generator.hpp ../../include/matador/object/attribute_generator.hpp
../../include/matador/object/basic_object_info.hpp ../../include/matador/object/basic_object_info.hpp
../../include/matador/object/constraint.hpp
../../include/matador/object/constraints_generator.hpp ../../include/matador/object/constraints_generator.hpp
../../include/matador/object/error_code.hpp ../../include/matador/object/error_code.hpp
../../include/matador/object/foreign_node_completer.hpp ../../include/matador/object/foreign_node_completer.hpp
../../include/matador/object/internal/shadow_repository.hpp ../../include/matador/object/internal/shadow_repository.hpp
../../include/matador/object/many_to_many_relation.hpp ../../include/matador/object/many_to_many_relation.hpp
../../include/matador/object/object.hpp ../../include/matador/object/object.hpp
../../include/matador/object/object_generator.hpp
../../include/matador/object/object_info.hpp ../../include/matador/object/object_info.hpp
../../include/matador/object/object_proxy.hpp ../../include/matador/object/object_proxy.hpp
../../include/matador/object/object_ptr.hpp ../../include/matador/object/object_ptr.hpp
@ -32,6 +32,7 @@ add_library(matador-core STATIC
../../include/matador/object/repository.hpp ../../include/matador/object/repository.hpp
../../include/matador/object/repository_node.hpp ../../include/matador/object/repository_node.hpp
../../include/matador/object/repository_node_iterator.hpp ../../include/matador/object/repository_node_iterator.hpp
../../include/matador/object/restriction.hpp
../../include/matador/sql/statement_cache.hpp ../../include/matador/sql/statement_cache.hpp
../../include/matador/utils/access.hpp ../../include/matador/utils/access.hpp
../../include/matador/utils/attribute_reader.hpp ../../include/matador/utils/attribute_reader.hpp
@ -80,15 +81,17 @@ add_library(matador-core STATIC
object/attribute.cpp object/attribute.cpp
object/attribute_generator.cpp object/attribute_generator.cpp
object/basic_object_info.cpp object/basic_object_info.cpp
object/constraint.cpp
object/constraints_generator.cpp object/constraints_generator.cpp
object/error_code.cpp object/error_code.cpp
object/foreign_node_completer.cpp object/foreign_node_completer.cpp
object/internal/shadow_repository.cpp object/internal/shadow_repository.cpp
object/object.cpp
object/object_generator.cpp
object/relation_endpoint.cpp object/relation_endpoint.cpp
object/repository.cpp object/repository.cpp
object/repository_node.cpp object/repository_node.cpp
object/repository_node_iterator.cpp object/repository_node_iterator.cpp
object/restriction.cpp
utils/default_type_traits.cpp utils/default_type_traits.cpp
utils/error.cpp utils/error.cpp
utils/errors.cpp utils/errors.cpp
@ -107,9 +110,6 @@ add_library(matador-core STATIC
utils/uuid.cpp utils/uuid.cpp
utils/value.cpp utils/value.cpp
utils/version.cpp utils/version.cpp
object/object.cpp
../../include/matador/object/object_generator.hpp
object/object_generator.cpp
) )
target_link_libraries(matador-core ${CMAKE_DL_LIBS}) target_link_libraries(matador-core ${CMAKE_DL_LIBS})

View File

@ -25,7 +25,7 @@ const std::list<attribute>& basic_object_info::attributes() const {
return object_->attributes(); return object_->attributes();
} }
const std::list<class constraint>& basic_object_info::constraints() const { const std::list<class restriction>& basic_object_info::constraints() const {
return object_->constraints(); return object_->constraints();
} }

View File

@ -5,13 +5,13 @@
#include <algorithm> #include <algorithm>
namespace matador::object { namespace matador::object {
constraints_generator::constraints_generator(std::list<class constraint> &constraints, const repository& repo, const std::shared_ptr<object> &obj) constraints_generator::constraints_generator(std::list<class restriction> &constraints, const repository& repo, const std::shared_ptr<object> &obj)
: constraints_(constraints) : constraints_(constraints)
, repo_(repo) , repo_(repo)
, obj_(obj) {} , obj_(obj) {}
void constraints_generator::create_pk_constraint(const std::string& name) const { void constraints_generator::create_pk_constraint(const std::string& name) const {
class constraint pk_constraint("PK_" + obj_->name()); class restriction pk_constraint("PK_" + obj_->name());
pk_constraint.options_ |= utils::constraints::PrimaryKey; pk_constraint.options_ |= utils::constraints::PrimaryKey;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_->attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
@ -26,7 +26,7 @@ void constraints_generator::create_fk_constraint(const std::type_index& ti, cons
return; return;
} }
const auto *pk_attribute = result.value().get().primary_key_attribute(); const auto *pk_attribute = result.value().get().primary_key_attribute();
class constraint pk_constraint("FK_" + obj_->name() + "_" + name); class restriction pk_constraint("FK_" + obj_->name() + "_" + name);
pk_constraint.options_ |= utils::constraints::ForeignKey; pk_constraint.options_ |= utils::constraints::ForeignKey;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_->attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
@ -38,7 +38,7 @@ void constraints_generator::create_fk_constraint(const std::type_index& ti, cons
} }
void constraints_generator::create_unique_constraint(const std::string& name) const { void constraints_generator::create_unique_constraint(const std::string& name) const {
class constraint pk_constraint("UK_" + obj_->name() + "_" + name); class restriction pk_constraint("UK_" + obj_->name() + "_" + name);
pk_constraint.options_ |= utils::constraints::Unique; pk_constraint.options_ |= utils::constraints::Unique;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_->attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(obj_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;

View File

@ -72,7 +72,7 @@ size_t object::constraint_count() const {
return constraints_.size(); return constraints_.size();
} }
const std::list<class constraint>& object::constraints() const { const std::list<class restriction>& object::constraints() const {
return constraints_; return constraints_;
} }

View File

@ -14,7 +14,7 @@ void object_generator::on_revision(const char* id, uint64_t& rev) {
} }
void object_generator::create_pk_constraint(const std::string& name) const { void object_generator::create_pk_constraint(const std::string& name) const {
class constraint pk_constraint("PK_" + object_->name()); class restriction pk_constraint("PK_" + object_->name());
pk_constraint.options_ |= utils::constraints::PrimaryKey; pk_constraint.options_ |= utils::constraints::PrimaryKey;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
@ -26,7 +26,7 @@ void object_generator::create_pk_constraint(const std::string& name) const {
void object_generator::create_fk_constraint(const std::type_index& ti, const std::string& name) const { void object_generator::create_fk_constraint(const std::type_index& ti, const std::string& name) const {
const auto obj = fk_object(ti); const auto obj = fk_object(ti);
const auto *pk_attribute = obj->primary_key_attribute(); const auto *pk_attribute = obj->primary_key_attribute();
class constraint pk_constraint("FK_" + object_->name() + "_" + name); class restriction pk_constraint("FK_" + object_->name() + "_" + name);
pk_constraint.options_ |= utils::constraints::ForeignKey; pk_constraint.options_ |= utils::constraints::ForeignKey;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;
@ -41,7 +41,7 @@ void object_generator::create_fk_constraint(const std::type_index& ti, const std
} }
void object_generator::create_unique_constraint(const std::string& name) const { void object_generator::create_unique_constraint(const std::string& name) const {
class constraint pk_constraint("UK_" + object_->name() + "_" + name); class restriction pk_constraint("UK_" + object_->name() + "_" + name);
pk_constraint.options_ |= utils::constraints::Unique; pk_constraint.options_ |= utils::constraints::Unique;
if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) { if (const auto pk_attr = find_attribute_by_name(name); pk_attr != std::end(object_->attributes_)) {
pk_constraint.attr_ = &*pk_attr; pk_constraint.attr_ = &*pk_attr;

View File

@ -1,15 +1,16 @@
#include "matador/object/constraint.hpp" #include "matador/object/restriction.hpp"
#include "matador/object/attribute.hpp" #include "matador/object/attribute.hpp"
namespace matador::object { namespace matador::object {
constraint::constraint(std::string name) restriction::restriction(std::string name)
: name_(std::move(name)) {} : name_(std::move(name)) {}
const std::string & constraint::name() const { const std::string & restriction::name() const {
return name_; return name_;
} }
const class attribute* constraint::attribute() const { const class attribute* restriction::attribute() const {
if (std::holds_alternative<class attribute*>(attr_)) { if (std::holds_alternative<class attribute*>(attr_)) {
return std::get<class attribute*>(attr_); return std::get<class attribute*>(attr_);
} }
@ -17,7 +18,7 @@ const class attribute* constraint::attribute() const {
return nullptr; return nullptr;
} }
std::string constraint::column_name() const { std::string restriction::column_name() const {
if (std::holds_alternative<class attribute*>(attr_)) { if (std::holds_alternative<class attribute*>(attr_)) {
return std::get<class attribute*>(attr_)->name(); return std::get<class attribute*>(attr_)->name();
} }
@ -28,31 +29,31 @@ std::string constraint::column_name() const {
return ""; return "";
} }
std::shared_ptr<object> constraint::owner() const { std::shared_ptr<object> restriction::owner() const {
return owner_; return owner_;
} }
bool constraint::is_primary_key_constraint() const { bool restriction::is_primary_key_constraint() const {
return utils::is_constraint_set(options_, utils::constraints::PrimaryKey); return utils::is_constraint_set(options_, utils::constraints::PrimaryKey);
} }
bool constraint::is_foreign_key_constraint() const { bool restriction::is_foreign_key_constraint() const {
return utils::is_constraint_set(options_, utils::constraints::ForeignKey); return utils::is_constraint_set(options_, utils::constraints::ForeignKey);
} }
bool constraint::is_unique_constraint() const { bool restriction::is_unique_constraint() const {
return utils::is_constraint_set(options_, utils::constraints::Unique); return utils::is_constraint_set(options_, utils::constraints::Unique);
} }
const std::string& constraint::ref_table_name() const { const std::string& restriction::ref_table_name() const {
return ref_table_name_; return ref_table_name_;
} }
const std::string& constraint::ref_column_name() const { const std::string& restriction::ref_column_name() const {
return ref_column_name_; return ref_column_name_;
} }
std::ostream & operator<<(std::ostream &os, const class constraint &c) { std::ostream & operator<<(std::ostream &os, const class restriction &c) {
os << "constraint " << c.name_ << " for column " << c.column_name(); os << "constraint " << c.name_ << " for column " << c.column_name();
return os; return os;
} }
@ -81,8 +82,8 @@ constraint_builder & constraint_builder::references(std::string table, std::stri
return *this; return *this;
} }
constraint_builder::operator class constraint() const { constraint_builder::operator class restriction() const {
class constraint c; class restriction c;
c.name_ = constraint_name; c.name_ = constraint_name;
c.attr_ = column_name; c.attr_ = column_name;
c.options_ = options_; c.options_ = options_;

View File

@ -181,7 +181,7 @@ utils::result<bool, utils::error> schema::table_exists(const std::string& table_
return c->exists(repo_.name(), table_name); return c->exists(repo_.name(), table_name);
} }
sql::query_context schema::build_add_constraint_context( const object::repository_node& node, const class object::constraint& cons ) const { sql::query_context schema::build_add_constraint_context( const object::repository_node& node, const class object::restriction& cons ) const {
if (cons.is_foreign_key_constraint()) { if (cons.is_foreign_key_constraint()) {
return query::query::alter() return query::query::alter()
.table(node.name()) .table(node.name())
@ -200,7 +200,7 @@ sql::query_context schema::build_add_constraint_context( const object::repositor
return {}; return {};
} }
sql::query_context schema::build_drop_constraint_context( const object::repository_node& node, const class object::constraint& cons ) const { sql::query_context schema::build_drop_constraint_context( const object::repository_node& node, const class object::restriction& cons ) const {
return query::query::alter() return query::query::alter()
.table(node.name()) .table(node.name())
.drop_constraint(cons.name()) .drop_constraint(cons.name())

View File

@ -76,7 +76,7 @@ utils::result<void, utils::error> session::create_schema() const {
return utils::ok<void>(); return utils::ok<void>();
} }
sql::query_context session::build_add_constraint_context(const std::string& table_name, const class object::constraint& cons, const sql::connection_ptr &conn) { sql::query_context session::build_add_constraint_context(const std::string& table_name, const class object::restriction& cons, const sql::connection_ptr &conn) {
if (cons.is_foreign_key_constraint()) { if (cons.is_foreign_key_constraint()) {
return query::query::alter() return query::query::alter()
.table(table_name) .table(table_name)

View File

@ -48,8 +48,8 @@ constraint_builder& constraint_builder::references( std::string table, std::stri
return *this; return *this;
} }
constraint_builder::operator object::constraint() const { constraint_builder::operator object::restriction() const {
return object::constraint{constraint_name}; return object::restriction{constraint_name};
} }
constraint_builder constraint( std::string name ) { constraint_builder constraint( std::string name ) {

View File

@ -18,27 +18,31 @@ executable_query query_create_intermediate::schema( const std::string& schema_na
return {context_}; return {context_};
} }
executable_query query_create_table_columns_intermediate::constraints( std::initializer_list<class object::constraint> constraints ) { executable_query query_create_table_columns_intermediate::constraints(const std::initializer_list<class object::restriction> constraints) {
return this->constraints(std::list(constraints)); return this->constraints(std::list(constraints));
} }
executable_query query_create_table_columns_intermediate::constraints( const std::list<class object::constraint>& constraints ) { executable_query query_create_table_columns_intermediate::constraints(const std::list<class object::restriction>& constraints) {
context_->parts.push_back(std::make_unique<internal::query_create_table_constraints_part>(constraints)); context_->parts.push_back(std::make_unique<internal::query_create_table_constraints_part>(constraints));
return {context_}; return {context_};
} }
query_create_table_columns_intermediate query_create_table_intermediate::columns( std::initializer_list<object::attribute> columns ) { query_create_table_columns_intermediate query_create_table_intermediate::columns(std::initializer_list<object::attribute> columns) {
context_->parts.push_back(std::make_unique<internal::query_create_table_columns_part>(columns)); context_->parts.push_back(std::make_unique<internal::query_create_table_columns_part>(columns));
return {context_}; return {context_};
} }
query_create_table_columns_intermediate query_create_table_intermediate::columns( const std::list<object::attribute>& columns ) { query_create_table_columns_intermediate query_create_table_intermediate::columns(const std::list<object::attribute>& columns) {
context_->parts.push_back(std::make_unique<internal::query_create_table_columns_part>(columns)); context_->parts.push_back(std::make_unique<internal::query_create_table_columns_part>(columns));
return {context_}; return {context_};
} }
query_create_table_columns_intermediate query_create_table_intermediate::columns( std::initializer_list<column> columns ) {} query_create_table_columns_intermediate query_create_table_intermediate::columns(std::initializer_list<column> columns) {
return {context_};
query_create_table_columns_intermediate query_create_table_intermediate::columns( const std::list<column>& columns ) {} }
query_create_table_columns_intermediate query_create_table_intermediate::columns(const std::list<column>& columns) {
return {context_};
}
} }

View File

@ -370,11 +370,11 @@ void query_create_table_columns_part::accept(query_part_visitor& visitor) {
visitor.visit(*this); visitor.visit(*this);
} }
query_create_table_constraints_part::query_create_table_constraints_part(const std::list<class object::constraint>& constraints) query_create_table_constraints_part::query_create_table_constraints_part(const std::list<class object::restriction>& constraints)
: query_part( sql::dialect_token::Constraint ) : query_part( sql::dialect_token::Constraint )
, constraints_(constraints) {} , constraints_(constraints) {}
const std::list<class object::constraint>& query_create_table_constraints_part::constraints() const { const std::list<class object::restriction>& query_create_table_constraints_part::constraints() const {
return constraints_; return constraints_;
} }

View File

@ -294,7 +294,7 @@ void query_compiler::visit(internal::query_create_part &/*create_part*/)
} }
std::string build_create_column(const object::attribute &col, const sql::dialect &d); std::string build_create_column(const object::attribute &col, const sql::dialect &d);
std::string build_constraint(const class object::constraint &cons, const sql::dialect &d); std::string build_constraint(const class object::restriction &cons, const sql::dialect &d);
void query_compiler::visit(internal::query_create_table_part &part) void query_compiler::visit(internal::query_create_table_part &part)
{ {
@ -392,7 +392,7 @@ std::string build_create_column(const object::attribute &col, const sql::dialect
return result; return result;
} }
std::string build_constraint(const class object::constraint& cons, const sql::dialect& d) { std::string build_constraint(const class object::restriction& cons, const sql::dialect& d) {
std::string result; std::string result;
if (!cons.name().empty()) { if (!cons.name().empty()) {
result.append(d.constraint()).append(" ").append(cons.name()).append(" "); result.append(d.constraint()).append(" ").append(cons.name()).append(" ");