mirror of https://github.com/adamdruppe/arsd.git
add pr discussion to the detailed discussion doc section
This commit is contained in:
parent
a955143c58
commit
760880e87f
|
@ -836,8 +836,75 @@ string toFieldName(T)(string s, bool isPlural = false)
|
||||||
generates get functions for a one-to-many relationship with the form
|
generates get functions for a one-to-many relationship with the form
|
||||||
`T2 get_<t2>(T1 row, Database db)` and
|
`T2 get_<t2>(T1 row, Database db)` and
|
||||||
`TabResultSet!T1 get_<t1>(T2 row, Database db)`
|
`TabResultSet!T1 get_<t1>(T2 row, Database db)`
|
||||||
Example:
|
|
||||||
```d
|
|
||||||
|
[children] also works with a one-to-many relationship, but they are different in that [children] only gives you the many in the one-to-many relationship and only works with a single foreign key at a time.
|
||||||
|
|
||||||
|
Say you have a User and Role tables where each User has a role and a Role can be used by multiple users, with:
|
||||||
|
|
||||||
|
---
|
||||||
|
/*
|
||||||
|
This would give you all of the users with the Role `role`.
|
||||||
|
*/
|
||||||
|
auto res = role.children!(User, Role).execute(db);
|
||||||
|
---
|
||||||
|
|
||||||
|
However if you wanted to get the Role of a user there would be no way of doing so with children. It doesn't work the other way around.
|
||||||
|
|
||||||
|
Also the big thing that one_to_many can do and children can not do is handle multiple relationships(Multiple foreign keys pointing to the same Table for example:
|
||||||
|
|
||||||
|
---
|
||||||
|
import std.stdio;
|
||||||
|
import arsd.sqlite;
|
||||||
|
import arsd.database_generation;
|
||||||
|
|
||||||
|
alias FK(alias toWhat) = ForeignKey!(toWhat, null);
|
||||||
|
|
||||||
|
@DBName("Professor") struct Professor
|
||||||
|
{
|
||||||
|
int id;
|
||||||
|
string name;
|
||||||
|
}
|
||||||
|
|
||||||
|
@DBName("Course") struct Course
|
||||||
|
{
|
||||||
|
int id;
|
||||||
|
@FK!(Professor.id) int professor_id;
|
||||||
|
@FK!(Professor.id) int assistant_id;
|
||||||
|
}
|
||||||
|
|
||||||
|
mixin(one_to_many!(Course.professor_id, "prof", "courses_taught"));
|
||||||
|
mixin(one_to_many!(Course.assistant_id, "assistant", "courses_assisted"));
|
||||||
|
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
Database db = new Sqlite("test2.db");
|
||||||
|
|
||||||
|
Course course = db.find!Course(1);
|
||||||
|
Professor prof = course.get_prof(db);
|
||||||
|
|
||||||
|
writeln(prof.get_courses_taught(db));
|
||||||
|
writeln(prof.get_courses_assisted(db));
|
||||||
|
}
|
||||||
|
---
|
||||||
|
|
||||||
|
Here there are 2 relationships from Course to Professor here. One of them you can get from get_courses_taught and the other one with get_courses_assisted.
|
||||||
|
If you attempt to use children like so
|
||||||
|
|
||||||
|
---
|
||||||
|
writeln(prof.children!(Course, Professor).execute(db));
|
||||||
|
---
|
||||||
|
|
||||||
|
You would get:
|
||||||
|
$(CONSOLE
|
||||||
|
source/arsd/database_generation.d(489,2): Error: static assert: "Course does not have exactly one foreign key of type Professor"
|
||||||
|
)
|
||||||
|
|
||||||
|
In conclusion, children is nice in that its simple, doesn't require mixins to create extra symbols(functions). However it doesn't handle the one in one-to-many relationships at all, and it also doesn't work in tables with more than one relationship to a table. And finally, you might prefer the syntax of `prof.get_courses(db)` over `prof.children!(Course, Professor).execute(db)`.
|
||||||
|
|
||||||
|
Examples:
|
||||||
|
|
||||||
|
---
|
||||||
Struct Role { int id; }
|
Struct Role { int id; }
|
||||||
struct User {
|
struct User {
|
||||||
@ForeignKey!(Role.id, "") int role_id;
|
@ForeignKey!(Role.id, "") int role_id;
|
||||||
|
@ -851,7 +918,8 @@ string toFieldName(T)(string s, bool isPlural = false)
|
||||||
Role role = user.get_role(db);
|
Role role = user.get_role(db);
|
||||||
auto users = role.get_users(db);
|
auto users = role.get_users(db);
|
||||||
}
|
}
|
||||||
```
|
---
|
||||||
|
|
||||||
if t2 or t1 are set as null they will be inferred from either
|
if t2 or t1 are set as null they will be inferred from either
|
||||||
the `DBName` attribute or from the name of the Table
|
the `DBName` attribute or from the name of the Table
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue