summaryrefslogtreecommitdiff
path: root/model/sql
diff options
context:
space:
mode:
authorxengineering <me@xengineering.eu>2024-04-06 18:45:49 +0200
committerxengineering <me@xengineering.eu>2024-04-06 20:22:04 +0200
commit4aee2c3b45caa890537a0fc0c850c4523a4eb56c (patch)
tree4818466a50c57360c24abbbde559edafc9125e29 /model/sql
parentf65b11a5b3011f370df5b4d32239225f3708ecd5 (diff)
downloadceres-4aee2c3b45caa890537a0fc0c850c4523a4eb56c.tar
ceres-4aee2c3b45caa890537a0fc0c850c4523a4eb56c.tar.zst
ceres-4aee2c3b45caa890537a0fc0c850c4523a4eb56c.zip
model: CRUD methods only for targeted objects
A create, read, update or delete (CRUD) method should only care about the object which provides the receiver and the relations to its child objects. For example the method func (r *Recipe) Create(tx *sql.Tx) error {} should only create the relational data inside the database for the recipe, not for the steps nested into this Recipe struct. This should be covered by the func (s *Step) Create(tx *sql.Tx) error {} method which is then called by `func (r *Recipe) Create()`. This has the advantage that every CRUD method has a constraint scope and is more unified since the Step CRUD methods now have a Step struct as receiver instead of a Recipe receiver.
Diffstat (limited to 'model/sql')
-rw-r--r--model/sql/migrate.sql2
1 files changed, 1 insertions, 1 deletions
diff --git a/model/sql/migrate.sql b/model/sql/migrate.sql
index 9577dab..f931af6 100644
--- a/model/sql/migrate.sql
+++ b/model/sql/migrate.sql
@@ -12,8 +12,8 @@ CREATE TABLE recipes (
CREATE TABLE steps (
id INTEGER PRIMARY KEY,
- recipe INTEGER NOT NULL,
'index' INTEGER NOT NULL,
text TEXT NOT NULL,
+ recipe INTEGER NOT NULL,
FOREIGN KEY(recipe) REFERENCES recipes(id)
);