Lightweight 0.1.0
Loading...
Searching...
No Matches
DataMapper Class Reference

Main API for mapping records to and from the database using high level C++ syntax. More...

#include <DataMapper.hpp>

Public Member Functions

 DataMapper ()
 Constructs a new data mapper, using the default connection.
 
 DataMapper (SqlConnection &&connection)
 Constructs a new data mapper, using the given connection.
 
 DataMapper (SqlConnectionString connectionString)
 Constructs a new data mapper, using the given connection string.
 
 DataMapper (DataMapper const &)=delete
 
 DataMapper (DataMapper &&) noexcept=default
 
DataMapperoperator= (DataMapper const &)=delete
 
DataMapperoperator= (DataMapper &&) noexcept=default
 
SqlConnection const & Connection () const noexcept
 Returns the connection reference used by this data mapper.
 
SqlConnectionConnection () noexcept
 Returns the mutable connection reference used by this data mapper.
 
template<typename Record >
std::vector< std::string > CreateTableString (SqlServerType serverType)
 Constructs a string list of SQL queries to create the table for the given record type.
 
template<typename FirstRecord , typename... MoreRecords>
std::vector< std::string > CreateTablesString (SqlServerType serverType)
 Constructs a string list of SQL queries to create the tables for the given record types.
 
template<typename Record >
void CreateTable ()
 Creates the table for the given record type.
 
template<typename FirstRecord , typename... MoreRecords>
void CreateTables ()
 Creates the tables for the given record types.
 
template<typename Record >
RecordPrimaryKeyType< Record > Create (Record &record)
 Creates a new record in the database.
 
template<typename Record >
RecordPrimaryKeyType< Record > CreateExplicit (Record const &record)
 Creates a new record in the database.
 
template<typename Record , typename... Args>
std::optional< Record > QuerySingle (SqlSelectQueryBuilder selectQuery, Args &&... args)
 Queries a single record from the database based on the given query.
 
template<typename Record , typename... PrimaryKeyTypes>
std::optional< Record > QuerySingle (PrimaryKeyTypes &&... primaryKeys)
 Queries a single record (based on primary key) from the database.
 
template<typename Record >
SqlQuerySingleBuilder< Record > QuerySingle ()
 Queries a single record from the database.
 
template<typename Record , typename ColumnName , typename T >
std::optional< Record > QuerySingleBy (ColumnName const &columnName, T const &value)
 Queries a single record by the given column name and value.
 
template<typename Record , typename... InputParameters>
std::vector< Record > Query (SqlSelectQueryBuilder::ComposedQuery const &selectQuery, InputParameters &&... inputParameters)
 Queries multiple records from the database, based on the given query.
 
template<typename Record , typename... InputParameters>
std::vector< Record > Query (std::string_view sqlQueryString, InputParameters &&... inputParameters)
 Queries multiple records from the database, based on the given query.
 
template<typename ElementMask , typename Record , typename... InputParameters>
std::vector< Record > Query (SqlSelectQueryBuilder::ComposedQuery const &selectQuery, InputParameters &&... inputParameters)
 
template<typename Record >
SqlAllFieldsQueryBuilder< Record > Query ()
 
template<typename Record , auto... ReferencedFields>
SqlSparseFieldQueryBuilder< Record, ReferencedFields... > QuerySparse ()
 
template<typename Record >
bool IsModified (Record const &record) const noexcept
 Checks if the record has any modified fields.
 
template<typename Record >
void Update (Record &record)
 Updates the record in the database.
 
template<typename Record >
std::size_t Delete (Record const &record)
 Deletes the record from the database.
 
template<typename Record >
std::size_t Count ()
 Counts the total number of records in the database for the given record type.
 
template<typename Record >
std::vector< Record > All ()
 Loads all records from the database for the given record type.
 
template<typename Record >
auto BuildQuery () -> SqlQueryBuilder
 Constructs an SQL query builder for the given record type.
 
SqlQueryBuilder FromTable (std::string_view tableName)
 Constructs an SQL query builder for the given table name.
 
template<typename Record >
void ClearModifiedState (Record &record) noexcept
 Clears the modified state of the record.
 
template<typename Record >
void LoadRelations (Record &record)
 Loads all direct relations to this record.
 
template<typename Record >
void ConfigureRelationAutoLoading (Record &record)
 
template<typename Record >
size_t Count ()
 
template<typename Record , typename... InputParameters>
LIGHTWEIGHT_FORCE_INLINE std::vector< Record > Query (SqlSelectQueryBuilder::ComposedQuery const &selectQuery, InputParameters &&... inputParameters)
 
template<typename Record , typename ValueType >
LIGHTWEIGHT_FORCE_INLINE void SetId (Record &record, ValueType &&id)
 
template<typename Record >
LIGHTWEIGHT_FORCE_INLINE Record & BindOutputColumns (Record &record)
 
template<typename ElementMask , typename Record >
LIGHTWEIGHT_FORCE_INLINE Record & BindOutputColumns (Record &record)
 

Static Public Member Functions

template<typename Record >
static std::string Inspect (Record const &record)
 Constructs a human readable string representation of the given record.
 

Detailed Description

Main API for mapping records to and from the database using high level C++ syntax.

A DataMapper instances operates on a single SQL connection and provides methods to create, read, update and delete records in the database.

See also
Field, BelongsTo, HasMany, HasManyThrough, HasOneThrough

Definition at line 439 of file DataMapper.hpp.

Constructor & Destructor Documentation

◆ DataMapper() [1/3]

DataMapper::DataMapper ( )
inline

Constructs a new data mapper, using the default connection.

Definition at line 443 of file DataMapper.hpp.

◆ DataMapper() [2/3]

DataMapper::DataMapper ( SqlConnection &&  connection)
inlineexplicit

Constructs a new data mapper, using the given connection.

Definition at line 450 of file DataMapper.hpp.

◆ DataMapper() [3/3]

DataMapper::DataMapper ( SqlConnectionString  connectionString)
inlineexplicit

Constructs a new data mapper, using the given connection string.

Definition at line 457 of file DataMapper.hpp.

Member Function Documentation

◆ Connection() [1/2]

SqlConnection const & DataMapper::Connection ( ) const
inlinenoexcept

Returns the connection reference used by this data mapper.

Definition at line 470 of file DataMapper.hpp.

◆ Connection() [2/2]

SqlConnection & DataMapper::Connection ( )
inlinenoexcept

Returns the mutable connection reference used by this data mapper.

Definition at line 476 of file DataMapper.hpp.

◆ Inspect()

template<typename Record >
std::string DataMapper::Inspect ( Record const &  record)
static

Constructs a human readable string representation of the given record.

Definition at line 753 of file DataMapper.hpp.

◆ CreateTableString()

template<typename Record >
std::vector< std::string > DataMapper::CreateTableString ( SqlServerType  serverType)

Constructs a string list of SQL queries to create the table for the given record type.

Definition at line 772 of file DataMapper.hpp.

References SqlMigrationQueryBuilder::CreateTable(), SqlQueryFormatter::Get(), SqlQueryBuilder::Migration(), and SqlForeignKeyReferenceDefinition::tableName.

◆ CreateTablesString()

template<typename FirstRecord , typename... MoreRecords>
std::vector< std::string > DataMapper::CreateTablesString ( SqlServerType  serverType)

Constructs a string list of SQL queries to create the tables for the given record types.

Definition at line 821 of file DataMapper.hpp.

◆ CreateTable()

template<typename Record >
void DataMapper::CreateTable ( )

Creates the table for the given record type.

Definition at line 833 of file DataMapper.hpp.

References SqlStatement::ExecuteDirect(), and SqlConnection::ServerType().

◆ CreateTables()

template<typename FirstRecord , typename... MoreRecords>
void DataMapper::CreateTables ( )

Creates the tables for the given record types.

Definition at line 843 of file DataMapper.hpp.

◆ Create()

template<typename Record >
RecordPrimaryKeyType< Record > DataMapper::Create ( Record &  record)

Creates a new record in the database.

The record is inserted into the database and the primary key is set on this record.

Returns
The primary key of the newly created record.

Definition at line 892 of file DataMapper.hpp.

References ClearModifiedState(), ConfigureRelationAutoLoading(), SqlGuid::Create(), CreateExplicit(), GetPrimaryKeyField(), and SqlStatement::LastInsertId().

◆ CreateExplicit()

template<typename Record >
RecordPrimaryKeyType< Record > DataMapper::CreateExplicit ( Record const &  record)

Creates a new record in the database.

Note
This is a variation of the Create() method and does not update the record's primary key.
Returns
The primary key of the newly created record.

Definition at line 850 of file DataMapper.hpp.

References SqlStatement::Execute(), SqlQueryBuilder::Insert(), SqlStatement::LastInsertId(), SqlStatement::Prepare(), and SqlConnection::Query().

Referenced by Create().

◆ QuerySingle() [1/3]

template<typename Record , typename... Args>
std::optional< Record > DataMapper::QuerySingle ( SqlSelectQueryBuilder  selectQuery,
Args &&...  args 
)

Queries a single record from the database based on the given query.

Parameters
selectQueryThe SQL select query to execute.
argsThe input parameters for the query.
Returns
The record if found, otherwise std::nullopt.

Definition at line 1069 of file DataMapper.hpp.

References SqlStatement::CloseCursor(), ConfigureRelationAutoLoading(), SqlStatement::Execute(), SqlStatement::FetchRow(), SqlSelectQueryBuilder::Field(), SqlSelectQueryBuilder::First(), and SqlStatement::Prepare().

◆ QuerySingle() [2/3]

template<typename Record , typename... PrimaryKeyTypes>
std::optional< Record > DataMapper::QuerySingle ( PrimaryKeyTypes &&...  primaryKeys)

Queries a single record (based on primary key) from the database.

The primary key(s) are used to identify the record to load. If the record is not found, std::nullopt is returned.

Definition at line 1036 of file DataMapper.hpp.

References SqlStatement::CloseCursor(), ConfigureRelationAutoLoading(), SqlStatement::Execute(), SqlStatement::FetchRow(), SqlStatement::Prepare(), SqlConnection::Query(), and SqlQueryBuilder::Select().

◆ QuerySingle() [3/3]

template<typename Record >
SqlQuerySingleBuilder< Record > DataMapper::QuerySingle ( )
inline

Queries a single record from the database.

Returns
A query builder for the given Record type that will also allow executing the query.
auto const record = dm.QuerySingle<Person>(personId)
.Where(FieldNameOf<&Person::id>, "=", 42)
.Get();
if (record.has_value())
std::println("Person: {}", DataMapper::Inspect(record.value()));
static std::string Inspect(Record const &record)
Constructs a human readable string representation of the given record.

Definition at line 545 of file DataMapper.hpp.

◆ QuerySingleBy()

template<typename Record , typename ColumnName , typename T >
std::optional< Record > DataMapper::QuerySingleBy ( ColumnName const &  columnName,
T const &  value 
)

Queries a single record by the given column name and value.

Parameters
columnNameThe name of the column to search.
valueThe value to search for.
Returns
The record if found, otherwise std::nullopt.

◆ Query() [1/4]

template<typename Record , typename... InputParameters>
std::vector< Record > DataMapper::Query ( std::string_view  sqlQueryString,
InputParameters &&...  inputParameters 
)

Queries multiple records from the database, based on the given query.

Definition at line 1106 of file DataMapper.hpp.

References ConfigureRelationAutoLoading(), SqlStatement::Execute(), SqlStatement::FetchRow(), SqlStatement::GetColumn(), SqlStatement::NumColumnsAffected(), and SqlStatement::Prepare().

◆ Query() [2/4]

template<typename ElementMask , typename Record , typename... InputParameters>
std::vector< Record > DataMapper::Query ( SqlSelectQueryBuilder::ComposedQuery const &  selectQuery,
InputParameters &&...  inputParameters 
)

Queries records from the database, based on the given query and can be used to retrieve only part of the record by specifying the ElementMask.

example:

struct Person
{
int id;
std::string name;
std::string email;
std::string phone;
std::string address;
std::string city;
std::string country;
};
auto infos = dm.Query<SqlElements<1,5>(RecordTableName<Person>.Fields({"name"sv, "city"sv}));
for(auto const& info : infos)
{
// only info.name and info.city are loaded
}
std::integer_sequence< size_t, Ints... > SqlElements
Represents a sequence of indexes that can be used alongside Query() to retrieve only part of the reco...

Definition at line 1146 of file DataMapper.hpp.

References ConfigureRelationAutoLoading(), SqlStatement::Execute(), SqlStatement::FetchRow(), and SqlStatement::Prepare().

◆ Query() [3/4]

template<typename Record >
SqlAllFieldsQueryBuilder< Record > DataMapper::Query ( )
inline

Queries records of given Record type.

Returns
A query builder for the given Record type. The query builder can be used to further refine the query. The query builder will execute the query when a method like All(), First(n), etc. is called.
auto const records = dm.Query<Person>()
.Where(FieldNameOf<&Person::is_active>, "=", true)
.All();

Definition at line 617 of file DataMapper.hpp.

◆ QuerySparse()

template<typename Record , auto... ReferencedFields>
SqlSparseFieldQueryBuilder< Record, ReferencedFields... > DataMapper::QuerySparse ( )
inline

Queries select fields from the given Record type.

The fields are given in form of &Record::field1, &Record::field2, ...

Returns
A query builder for the given Record type. The query builder can be used to further refine the query. The query builder will execute the query when a method like All(), First(n), etc. is called.
auto const records = dm.QuerySparse<Person, &Person::id, &Person::name, &Person::age>()
.Where(FieldNameOf<&Person::is_active>, "=", true)
.All();

Definition at line 646 of file DataMapper.hpp.

◆ IsModified()

template<typename Record >
bool DataMapper::IsModified ( Record const &  record) const
noexcept

Checks if the record has any modified fields.

Definition at line 933 of file DataMapper.hpp.

◆ Update()

template<typename Record >
void DataMapper::Update ( Record &  record)

Updates the record in the database.

Definition at line 950 of file DataMapper.hpp.

References ClearModifiedState(), SqlStatement::Execute(), SqlStatement::Prepare(), SqlConnection::Query(), and SqlQueryBuilder::Update().

◆ Delete()

template<typename Record >
std::size_t DataMapper::Delete ( Record const &  record)

Deletes the record from the database.

Definition at line 989 of file DataMapper.hpp.

References SqlQueryBuilder::Delete(), SqlStatement::Execute(), SqlStatement::NumRowsAffected(), SqlStatement::Prepare(), and SqlConnection::Query().

◆ All()

template<typename Record >
std::vector< Record > DataMapper::All ( )

Loads all records from the database for the given record type.

Definition at line 1030 of file DataMapper.hpp.

References SqlSelectQueryBuilder::All(), SqlConnection::Query(), and SqlQueryBuilder::Select().

◆ BuildQuery()

template<typename Record >
auto DataMapper::BuildQuery ( ) -> SqlQueryBuilder
inline

Constructs an SQL query builder for the given record type.

Definition at line 686 of file DataMapper.hpp.

References SqlConnection::Query().

◆ FromTable()

SqlQueryBuilder DataMapper::FromTable ( std::string_view  tableName)
inline

Constructs an SQL query builder for the given table name.

Definition at line 692 of file DataMapper.hpp.

References SqlConnection::Query().

◆ ClearModifiedState()

template<typename Record >
void DataMapper::ClearModifiedState ( Record &  record)
noexcept

Clears the modified state of the record.

Definition at line 1164 of file DataMapper.hpp.

Referenced by Create(), and Update().

◆ LoadRelations()

template<typename Record >
void DataMapper::LoadRelations ( Record &  record)

Loads all direct relations to this record.

Definition at line 1399 of file DataMapper.hpp.

◆ ConfigureRelationAutoLoading()

template<typename Record >
void DataMapper::ConfigureRelationAutoLoading ( Record &  record)

◆ Count()

template<typename Record >
size_t DataMapper::Count ( )

Definition at line 1017 of file DataMapper.hpp.

◆ Query() [4/4]

template<typename Record , typename... InputParameters>
LIGHTWEIGHT_FORCE_INLINE std::vector< Record > DataMapper::Query ( SqlSelectQueryBuilder::ComposedQuery const &  selectQuery,
InputParameters &&...  inputParameters 
)
inline

Definition at line 1096 of file DataMapper.hpp.

◆ SetId()

template<typename Record , typename ValueType >
LIGHTWEIGHT_FORCE_INLINE void DataMapper::SetId ( Record &  record,
ValueType &&  id 
)
inline

Definition at line 1425 of file DataMapper.hpp.

◆ BindOutputColumns() [1/2]

template<typename Record >
LIGHTWEIGHT_FORCE_INLINE Record & DataMapper::BindOutputColumns ( Record &  record)
inline

Definition at line 1442 of file DataMapper.hpp.

◆ BindOutputColumns() [2/2]

template<typename ElementMask , typename Record >
LIGHTWEIGHT_FORCE_INLINE Record & DataMapper::BindOutputColumns ( Record &  record)
inline

Definition at line 1456 of file DataMapper.hpp.


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