Lightweight 0.1.0
Loading...
Searching...
No Matches
BelongsTo< TheReferencedField, ColumnNameOverrideString > Class Template Reference

Represents a one-to-one relationship. More...

#include <BelongsTo.hpp>

Public Types

using ReferencedRecord = MemberClassType< decltype(TheReferencedField)>
 Represents the record type of the other field.
 
using ValueType = typename std::remove_cvref_t< decltype(std::declval< ReferencedRecord >().*ReferencedField)>::ValueType
 Represents the column type of the foreign key, matching the primary key of the other record.
 

Public Member Functions

template<typename... S>
requires std::constructible_from<ValueType, S...>
constexpr BelongsTo (S &&... value) noexcept
 
constexpr BelongsTo (ReferencedRecord const &other) noexcept
 
BelongsTooperator= (SqlNullType) noexcept
 
BelongsTooperator= (ReferencedRecord &other)
 
LIGHTWEIGHT_FORCE_INLINE constexpr void SetModified (bool value) noexcept
 Marks the field as modified or unmodified.
 
LIGHTWEIGHT_FORCE_INLINE constexpr bool IsModified () const noexcept
 Checks if the field is modified.
 
LIGHTWEIGHT_FORCE_INLINE constexpr ValueType const & Value () const noexcept
 Retrieves the reference to the value of the field.
 
LIGHTWEIGHT_FORCE_INLINE constexpr ValueTypeMutableValue () noexcept
 Retrieves the mutable reference to the value of the field.
 
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecordRecord () noexcept
 Retrieves a record from the relationship.
 
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord const & Record () const noexcept
 Retrieves an immutable reference to the record from the relationship.
 
LIGHTWEIGHT_FORCE_INLINE constexpr bool IsLoaded () const noexcept
 Checks if the record is loaded into memory.
 
LIGHTWEIGHT_FORCE_INLINE void Unload () noexcept
 Unloads the record from memory.
 
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecordoperator* () noexcept
 Retrieves the record from the relationship.
 
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord const & operator* () const noexcept
 Retrieves the record from the relationship.
 
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecordoperator-> () noexcept
 Retrieves the record from the relationship.
 
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord const * operator-> () const noexcept
 Retrieves the record from the relationship.
 
LIGHTWEIGHT_FORCE_INLINE constexpr bool operator! () const noexcept
 Checks if the field value is NULL.
 
LIGHTWEIGHT_FORCE_INLINE constexpr operator bool () const noexcept
 Checks if the field value is not NULL.
 
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecordEmplaceRecord ()
 Emplaces a record into the relationship. This will mark the relationship as loaded.
 
LIGHTWEIGHT_FORCE_INLINE void BindOutputColumn (SQLSMALLINT outputIndex, SqlStatement &stmt)
 
template<auto OtherReferencedField>
std::weak_ordering operator<=> (BelongsTo< OtherReferencedField > const &other) const noexcept
 
template<detail::FieldElementType T, PrimaryKey IsPrimaryKeyValue = PrimaryKey::No>
std::weak_ordering operator<=> (Field< T, IsPrimaryKeyValue > const &other) const noexcept
 
template<auto OtherReferencedField>
bool operator== (BelongsTo< OtherReferencedField > const &other) const noexcept
 
template<auto OtherReferencedField>
bool operator!= (BelongsTo< OtherReferencedField > const &other) const noexcept
 
template<detail::FieldElementType T, PrimaryKey IsPrimaryKeyValue = PrimaryKey::No>
bool operator== (Field< T, IsPrimaryKeyValue > const &other) const noexcept
 
template<detail::FieldElementType T, PrimaryKey IsPrimaryKeyValue = PrimaryKey::No>
bool operator!= (Field< T, IsPrimaryKeyValue > const &other) const noexcept
 
void SetAutoLoader (Loader loader) noexcept
 Used internally to configure on-demand loading of the record.
 

Static Public Attributes

static constexpr auto ReferencedField = TheReferencedField
 The field in the other record that references the current record.
 
static constexpr std::string_view ColumnNameOverride
 If not an empty string, this value will be used as the column name in the database.
 
static constexpr auto IsOptional = true
 
static constexpr auto IsMandatory = !IsOptional
 
static constexpr auto IsPrimaryKey = false
 
static constexpr auto IsAutoIncrementPrimaryKey = false
 

Detailed Description

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
class BelongsTo< TheReferencedField, ColumnNameOverrideString >

Represents a one-to-one relationship.

The TheReferencedField parameter is the field in the other record that references the current record, in the form of &OtherRecord::Field. Other Field must be a primary key.

Definition at line 25 of file BelongsTo.hpp.

Member Typedef Documentation

◆ ReferencedRecord

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
using BelongsTo< TheReferencedField, ColumnNameOverrideString >::ReferencedRecord = MemberClassType<decltype(TheReferencedField)>

Represents the record type of the other field.

Definition at line 40 of file BelongsTo.hpp.

◆ ValueType

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
using BelongsTo< TheReferencedField, ColumnNameOverrideString >::ValueType = typename std::remove_cvref_t<decltype(std::declval<ReferencedRecord>().*ReferencedField)>::ValueType

Represents the column type of the foreign key, matching the primary key of the other record.

Definition at line 46 of file BelongsTo.hpp.

Constructor & Destructor Documentation

◆ BelongsTo() [1/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
template<typename... S>
requires std::constructible_from<ValueType, S...>
constexpr BelongsTo< TheReferencedField, ColumnNameOverrideString >::BelongsTo ( S &&...  value)
inlineconstexprnoexcept

Definition at line 56 of file BelongsTo.hpp.

◆ BelongsTo() [2/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
constexpr BelongsTo< TheReferencedField, ColumnNameOverrideString >::BelongsTo ( ReferencedRecord const &  other)
inlineconstexprnoexcept

Definition at line 61 of file BelongsTo.hpp.

Member Function Documentation

◆ operator=() [1/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
BelongsTo & BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator= ( SqlNullType  )
inlinenoexcept

Definition at line 68 of file BelongsTo.hpp.

◆ operator=() [2/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
BelongsTo & BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator= ( ReferencedRecord other)
inline

Definition at line 79 of file BelongsTo.hpp.

◆ SetModified()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr void BelongsTo< TheReferencedField, ColumnNameOverrideString >::SetModified ( bool  value)
inlineconstexprnoexcept

Marks the field as modified or unmodified.

Definition at line 93 of file BelongsTo.hpp.

◆ IsModified()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr bool BelongsTo< TheReferencedField, ColumnNameOverrideString >::IsModified ( ) const
inlineconstexprnoexcept

Checks if the field is modified.

Definition at line 96 of file BelongsTo.hpp.

◆ Value()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr ValueType const & BelongsTo< TheReferencedField, ColumnNameOverrideString >::Value ( ) const
inlineconstexprnoexcept

Retrieves the reference to the value of the field.

Definition at line 99 of file BelongsTo.hpp.

◆ MutableValue()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr ValueType & BelongsTo< TheReferencedField, ColumnNameOverrideString >::MutableValue ( )
inlineconstexprnoexcept

Retrieves the mutable reference to the value of the field.

Definition at line 102 of file BelongsTo.hpp.

◆ Record() [1/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord & BelongsTo< TheReferencedField, ColumnNameOverrideString >::Record ( )
inlineconstexprnoexcept

Retrieves a record from the relationship.

Definition at line 105 of file BelongsTo.hpp.

◆ Record() [2/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord const & BelongsTo< TheReferencedField, ColumnNameOverrideString >::Record ( ) const
inlineconstexprnoexcept

Retrieves an immutable reference to the record from the relationship.

Definition at line 108 of file BelongsTo.hpp.

◆ IsLoaded()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr bool BelongsTo< TheReferencedField, ColumnNameOverrideString >::IsLoaded ( ) const
inlineconstexprnoexcept

Checks if the record is loaded into memory.

Definition at line 111 of file BelongsTo.hpp.

◆ Unload()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE void BelongsTo< TheReferencedField, ColumnNameOverrideString >::Unload ( )
inlinenoexcept

Unloads the record from memory.

Definition at line 114 of file BelongsTo.hpp.

◆ operator*() [1/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord & BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator* ( )
inlineconstexprnoexcept

Retrieves the record from the relationship.

Definition at line 117 of file BelongsTo.hpp.

◆ operator*() [2/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord const & BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator* ( ) const
inlineconstexprnoexcept

Retrieves the record from the relationship.

Definition at line 120 of file BelongsTo.hpp.

◆ operator->() [1/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord * BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator-> ( )
inlineconstexprnoexcept

Retrieves the record from the relationship.

Definition at line 123 of file BelongsTo.hpp.

◆ operator->() [2/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord const * BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator-> ( ) const
inlineconstexprnoexcept

Retrieves the record from the relationship.

Definition at line 126 of file BelongsTo.hpp.

◆ operator!()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr bool BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator! ( ) const
inlineconstexprnoexcept

Checks if the field value is NULL.

Definition at line 129 of file BelongsTo.hpp.

◆ operator bool()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator bool ( ) const
inlineexplicitconstexprnoexcept

Checks if the field value is not NULL.

Definition at line 132 of file BelongsTo.hpp.

◆ EmplaceRecord()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE constexpr ReferencedRecord & BelongsTo< TheReferencedField, ColumnNameOverrideString >::EmplaceRecord ( )
inlineconstexpr

Emplaces a record into the relationship. This will mark the relationship as loaded.

Definition at line 135 of file BelongsTo.hpp.

◆ BindOutputColumn()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
LIGHTWEIGHT_FORCE_INLINE void BelongsTo< TheReferencedField, ColumnNameOverrideString >::BindOutputColumn ( SQLSMALLINT  outputIndex,
SqlStatement stmt 
)
inline

Definition at line 137 of file BelongsTo.hpp.

◆ operator<=>() [1/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
template<auto OtherReferencedField>
std::weak_ordering BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator<=> ( BelongsTo< OtherReferencedField > const &  other) const
inlinenoexcept

Definition at line 141 of file BelongsTo.hpp.

◆ operator<=>() [2/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
template<detail::FieldElementType T, PrimaryKey IsPrimaryKeyValue = PrimaryKey::No>
std::weak_ordering BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator<=> ( Field< T, IsPrimaryKeyValue > const &  other) const
inlinenoexcept

Definition at line 147 of file BelongsTo.hpp.

◆ operator==() [1/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
template<auto OtherReferencedField>
bool BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator== ( BelongsTo< OtherReferencedField > const &  other) const
inlinenoexcept

Definition at line 153 of file BelongsTo.hpp.

◆ operator!=() [1/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
template<auto OtherReferencedField>
bool BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator!= ( BelongsTo< OtherReferencedField > const &  other) const
inlinenoexcept

Definition at line 159 of file BelongsTo.hpp.

◆ operator==() [2/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
template<detail::FieldElementType T, PrimaryKey IsPrimaryKeyValue = PrimaryKey::No>
bool BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator== ( Field< T, IsPrimaryKeyValue > const &  other) const
inlinenoexcept

Definition at line 165 of file BelongsTo.hpp.

◆ operator!=() [2/2]

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
template<detail::FieldElementType T, PrimaryKey IsPrimaryKeyValue = PrimaryKey::No>
bool BelongsTo< TheReferencedField, ColumnNameOverrideString >::operator!= ( Field< T, IsPrimaryKeyValue > const &  other) const
inlinenoexcept

Definition at line 171 of file BelongsTo.hpp.

◆ SetAutoLoader()

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
void BelongsTo< TheReferencedField, ColumnNameOverrideString >::SetAutoLoader ( Loader  loader)
inlinenoexcept

Used internally to configure on-demand loading of the record.

Definition at line 182 of file BelongsTo.hpp.

Member Data Documentation

◆ ReferencedField

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
constexpr auto BelongsTo< TheReferencedField, ColumnNameOverrideString >::ReferencedField = TheReferencedField
staticconstexpr

The field in the other record that references the current record.

Definition at line 29 of file BelongsTo.hpp.

◆ ColumnNameOverride

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
constexpr std::string_view BelongsTo< TheReferencedField, ColumnNameOverrideString >::ColumnNameOverride
staticconstexpr
Initial value:
= []() consteval {
if constexpr (!std::same_as<decltype(ColumnNameOverrideString), std::nullopt_t>)
return std::string_view{ColumnNameOverrideString};
else
return std::string_view {};
}()

If not an empty string, this value will be used as the column name in the database.

Definition at line 32 of file BelongsTo.hpp.

◆ IsOptional

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
constexpr auto BelongsTo< TheReferencedField, ColumnNameOverrideString >::IsOptional = true
staticconstexpr

Definition at line 49 of file BelongsTo.hpp.

◆ IsMandatory

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
constexpr auto BelongsTo< TheReferencedField, ColumnNameOverrideString >::IsMandatory = !IsOptional
staticconstexpr

Definition at line 50 of file BelongsTo.hpp.

◆ IsPrimaryKey

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
constexpr auto BelongsTo< TheReferencedField, ColumnNameOverrideString >::IsPrimaryKey = false
staticconstexpr

Definition at line 51 of file BelongsTo.hpp.

◆ IsAutoIncrementPrimaryKey

template<auto TheReferencedField, auto ColumnNameOverrideString = std::nullopt>
constexpr auto BelongsTo< TheReferencedField, ColumnNameOverrideString >::IsAutoIncrementPrimaryKey = false
staticconstexpr

Definition at line 52 of file BelongsTo.hpp.


The documentation for this class was generated from the following file: