From 25cfaa239fba4c2496a2868125807b9c065cf3ad Mon Sep 17 00:00:00 2001 From: klaus triendl Date: Sat, 22 Jun 2024 19:07:08 +0200 Subject: [PATCH] Corrected self-join example --- examples/self_join.cpp | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/examples/self_join.cpp b/examples/self_join.cpp index 66085e6a..46cdda68 100644 --- a/examples/self_join.cpp +++ b/examples/self_join.cpp @@ -31,6 +31,9 @@ struct Employee { std::string fax; std::string email; }; +#ifdef SQLITE_ORM_WITH_CPP20_ALIASES +inline constexpr sqlite_orm::orm_table_reference auto employee = sqlite_orm::c(); +#endif /** * This is how custom alias is made: @@ -208,9 +211,10 @@ int main() { // ON m.ReportsTo = employees.EmployeeId #ifdef SQLITE_ORM_WITH_CPP20_ALIASES constexpr orm_table_alias auto m = "m"_alias.for_(); - auto firstNames = storage.select(columns(m->*&Employee::firstName || " " || m->*&Employee::lastName, - &Employee::firstName || " " || &Employee::lastName), - inner_join(on(m->*&Employee::reportsTo == &Employee::employeeId))); + auto firstNames = + storage.select(columns(m->*&Employee::firstName || " " || m->*&Employee::lastName, + employee->*&Employee::firstName || " " || employee->*&Employee::lastName), + inner_join(on(m->*&Employee::reportsTo == employee->*&Employee::employeeId))); cout << "firstNames count = " << firstNames.size() << endl; for(auto& row: firstNames) { cout << std::get<0>(row) << '\t' << std::get<1>(row) << endl; @@ -219,7 +223,7 @@ int main() { using als = alias_m; auto firstNames = storage.select( columns(alias_column(&Employee::firstName) || " " || alias_column(&Employee::lastName), - &Employee::firstName || " " || &Employee::lastName), + &Employee::firstName || c(" ") || &Employee::lastName), inner_join(on(alias_column(&Employee::reportsTo) == &Employee::employeeId))); cout << "firstNames count = " << firstNames.size() << endl; for(auto& row: firstNames) { @@ -240,9 +244,10 @@ int main() { #ifdef SQLITE_ORM_WITH_CPP20_ALIASES static_assert(std::is_empty_v>); constexpr orm_table_alias auto emp = custom_alias{}; - auto firstNames = storage.select(columns(emp->*&Employee::firstName || " " || emp->*&Employee::lastName, - &Employee::firstName || " " || &Employee::lastName), - inner_join(on(emp->*&Employee::reportsTo == &Employee::employeeId))); + auto firstNames = + storage.select(columns(emp->*&Employee::firstName || " " || emp->*&Employee::lastName, + employee->*&Employee::firstName || " " || employee->*&Employee::lastName), + inner_join(on(emp->*&Employee::reportsTo == employee->*&Employee::employeeId))); cout << "firstNames count = " << firstNames.size() << endl; for(auto& row: firstNames) { cout << std::get<0>(row) << '\t' << std::get<1>(row) << endl; @@ -251,7 +256,7 @@ int main() { using als = custom_alias; auto firstNames = storage.select( columns(alias_column(&Employee::firstName) || " " || alias_column(&Employee::lastName), - &Employee::firstName || " " || &Employee::lastName), + &Employee::firstName || c(" ") || &Employee::lastName), inner_join(on(alias_column(&Employee::reportsTo) == &Employee::employeeId))); cout << "firstNames count = " << firstNames.size() << endl; for(auto& row: firstNames) {