diff options
author | xengineering <me@xengineering.eu> | 2024-05-08 21:53:13 +0200 |
---|---|---|
committer | xengineering <me@xengineering.eu> | 2024-05-08 22:26:00 +0200 |
commit | 0ba1a7661a81200db98e40149eef1e39fd22f407 (patch) | |
tree | 387b0d130fe444e964629d1a3168cfca050e70ca /main.go | |
parent | 5396273447260b88e9aea77bb3347ed8ad4b1ae5 (diff) | |
download | ceres-0ba1a7661a81200db98e40149eef1e39fd22f407.tar ceres-0ba1a7661a81200db98e40149eef1e39fd22f407.tar.zst ceres-0ba1a7661a81200db98e40149eef1e39fd22f407.zip |
Introduce model.Transaction()
It is a very common pattern that some function needs to access the
database and wants to wrap all the actions into one transaction.
The advantage of a transaction is that it is ACID:
- atomic
- consistent
- isolated
- durable
In Go it is required to request a new transaction, execute functionality
on it and handle rollback or commit of this transaction based on the
success of the operation.
All this and the error handling can be written down in the
model.Transaction() function exactly once. The full signature of it is:
func Transaction(f func(*sql.Tx) error) error
It requires a function or closure passed as argument which takes the
transaction (*sql.Tx) and returns an error which might be nil.
This is very generic. It is applied to:
- injecting test data
- database migrations
- data read requests
- data write requests
Diffstat (limited to 'main.go')
0 files changed, 0 insertions, 0 deletions