Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/billowdev/go-repo-in-transaction-repo-level-pattern
🥺(Code Duplication) Transaction at the Repository Level
https://github.com/billowdev/go-repo-in-transaction-repo-level-pattern
Last synced: 3 days ago
JSON representation
🥺(Code Duplication) Transaction at the Repository Level
- Host: GitHub
- URL: https://github.com/billowdev/go-repo-in-transaction-repo-level-pattern
- Owner: billowdev
- Created: 2024-09-07T15:21:02.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-09-07T15:21:39.000Z (4 months ago)
- Last Synced: 2024-11-08T09:44:21.300Z (about 2 months ago)
- Homepage:
- Size: 1.95 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# go-repo-in-transaction-repo-level
Transaction at the Repository Level## Approach: Transaction at the Repository Level (BeginTransaction Method)
Here, each repository has its own BeginTransaction method, and the service manages the transaction by passing the transaction context to the repositories.
`Pros`:
- Granularity: Allows fine-grained control over transactions, enabling different repositories to manage their own transactions.
- Direct Control: Gives the service layer direct control over the transaction process, which can be useful in certain scenarios.`Cons`:
- Code Duplication: Each repository needs to implement its own transaction management logic, leading to potential code duplication.
- Complexity: Increases the complexity of the service layer, as it must coordinate transaction management across multiple repositories.
Risk of Inconsistency: Higher risk of inconsistencies if the transaction context is not managed properly across repositories.`Best Practice`:
This approach is less common in Hexagonal Architecture because it mixes concerns and adds complexity. It's usually better to centralize transaction management rather than spreading it across repositories.
Suitable only in cases where each repository truly needs its own independent transaction management.