mirror of
https://github.com/gogf/gf.git
synced 2025-04-05 11:18:50 +08:00
43 lines
1.5 KiB
Go
43 lines
1.5 KiB
Go
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
|
|
//
|
|
// This Source Code Form is subject to the terms of the MIT License.
|
|
// If a copy of the MIT was not distributed with this file,
|
|
// You can obtain one at https://github.com/gogf/gf.
|
|
|
|
package gdb
|
|
|
|
import (
|
|
"context"
|
|
)
|
|
|
|
// Transaction wraps the transaction logic using function `f`.
|
|
// It rollbacks the transaction and returns the error from function `f` if
|
|
// it returns non-nil error. It commits the transaction and returns nil if
|
|
// function `f` returns nil.
|
|
//
|
|
// Note that, you should not Commit or Rollback the transaction in function `f`
|
|
// as it is automatically handled by this function.
|
|
func (m *Model) Transaction(ctx context.Context, f func(ctx context.Context, tx TX) error) (err error) {
|
|
if ctx == nil {
|
|
ctx = m.GetCtx()
|
|
}
|
|
if m.tx != nil {
|
|
return m.tx.Transaction(ctx, f)
|
|
}
|
|
return m.db.Transaction(ctx, f)
|
|
}
|
|
|
|
// TransactionWithOptions executes transaction with options.
|
|
// The parameter `opts` specifies the transaction options.
|
|
// The parameter `f` specifies the function that will be called within the transaction.
|
|
// If f returns error, the transaction will be rolled back, or else the transaction will be committed.
|
|
func (m *Model) TransactionWithOptions(ctx context.Context, opts TxOptions, f func(ctx context.Context, tx TX) error) (err error) {
|
|
if ctx == nil {
|
|
ctx = m.GetCtx()
|
|
}
|
|
if m.tx != nil {
|
|
return m.tx.Transaction(ctx, f)
|
|
}
|
|
return m.db.TransactionWithOptions(ctx, opts, f)
|
|
}
|