/
debug_perf.go
executable file
·82 lines (74 loc) · 2.4 KB
/
debug_perf.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
package data
import (
"context"
"errors"
"github.com/xiaohubai/go-grpc-layout/internal/data/model"
"golang.org/x/sync/errgroup"
"gorm.io/gorm"
)
func (d *dataRepo) FirstDebugPerf(ctx context.Context, debugPerf *model.DebugPerf) (
res *model.DebugPerf, err error) {
db := d.data.db.DebugPerf.WithContext(ctx)
if debugPerf.UID != "" {
db = db.Where(d.data.db.DebugPerf.UID.Eq(debugPerf.UID))
}
return db.First()
}
func (d *dataRepo) AddDebugPerf(ctx context.Context, debugPerf *model.DebugPerf) (err error) {
db := d.data.db.DebugPerf.WithContext(ctx)
return db.Create(debugPerf)
}
func (d *dataRepo) DeleteDebugPerf(ctx context.Context, debugPerf *model.DebugPerf) (err error) {
db := d.data.db.DebugPerf.WithContext(ctx)
_, err = db.Where(d.data.db.DebugPerf.UID.Eq(debugPerf.UID)).Unscoped().Delete()
return
}
func (d *dataRepo) UpdateDebugPerf(ctx context.Context, debugPerf *model.DebugPerf) (err error) {
db := d.data.db.DebugPerf.WithContext(ctx)
_, err = db.Omit(d.data.db.DebugPerf.ID).Where(d.data.db.DebugPerf.UID.Eq(debugPerf.UID)).Updates(debugPerf)
return
}
func (d *dataRepo) TransactionDebugPerf(ctx context.Context, debugPerf *model.DebugPerf) (err error) {
tx := d.data.db.Begin()
var g errgroup.Group
g.Go(func() error {
data, err := tx.DebugPerf.WithContext(ctx).Where(d.data.db.DebugPerf.UID.Eq(debugPerf.UID)).First()
if err != nil && err != gorm.ErrRecordNotFound {
_ = tx.Rollback()
return errors.New("获取测试信息失败")
}
if data == nil {
err = tx.DebugPerf.WithContext(ctx).Create(&model.DebugPerf{
UID: debugPerf.UID,
Text: debugPerf.Text,
})
if err != nil {
_ = tx.Rollback()
return errors.New("插入测试表数据失败")
}
}
user, err := tx.User.WithContext(ctx).Where(d.data.db.User.UID.Eq(debugPerf.UID)).First()
if err != nil {
_ = tx.Rollback()
return errors.New("获取用户信息失败")
}
_, err = tx.DebugPerf.WithContext(ctx).Omit(d.data.db.DebugPerf.ID).Where(d.data.db.DebugPerf.UID.Eq(debugPerf.UID)).Updates(&model.DebugPerf{
UID: debugPerf.UID,
Username: user.Username,
Motto: user.Motto,
Text: debugPerf.Text,
CreateUser: debugPerf.CreateUser,
UpdateUser: debugPerf.CreateUser,
})
if err != nil {
_ = tx.Rollback()
return errors.New("更新测试表信息失败")
}
return nil
})
if err := g.Wait(); err != nil {
return err
}
_ = tx.Commit()
return nil
}