func (r *ewalletRepo) Update(ctx context.Context, req *biz.Ewallet) (*biz.Ewallet, error) { // 开启事务 tx, err := r.data.db.Tx(ctx) if err != nil { return nil, biz.ErrRecordAlreadyExists } // 修改 sum, err := tx.Ewallet.Update().SetBalance(req.Balance).SetFrozenAmount(req.Frozen_Amount).Where(ewallet.HasCustomerWith(customer.ID(req.Id))).Save(ctx) if err != nil { _ = tx.Rollback() return nil, v1.ErrorUniversalError(err.Error()) } else if sum != 1 { _ = tx.Rollback() return nil, v1.ErrorUniversalError(err.Error()) } // 查询 result, err := tx.Ewallet.Query().Where(ewallet.HasCustomerWith(customer.ID(req.Id))).Only(ctx) if err != nil { _ = tx.Rollback() return nil, v1.ErrorUniversalError(err.Error()) } cacheKey := r.CacheKey(req.Id) _ = r.data.cache.Del(ctx, cacheKey) err = r.data.setCache(ctx, cacheKey, result) if err != nil { _ = tx.Rollback() return nil, biz.ErrRecordAlreadyExists } // 执行事务 err = tx.Commit() if err != nil { // 事务回滚 _ = tx.Rollback() return nil, biz.ErrRecordAlreadyExists } return r.composes(result, err) } 改成不是直接修改数据库,而是修改缓存 添加到缓存 从底部存 头部取 使用LPOP 移出并获取列表的第一个元素 RPUSH 在列表中添加一个或多个值到列表尾部 展示修改后的代码并解释
时间: 2024-04-14 21:30:09 浏览: 109
go-context.v2:上下文库,用于简单的控件执行流程
func (r *ewalletRepo) Update(ctx context.Context, req *biz.Ewallet) (*biz.Ewallet, error) {
// 从缓存中获取原始数据
cacheKey := r.CacheKey(req.Id)
oldData, err := r.data.cache.Get(ctx, cacheKey)
if err != nil {
return nil, v1.ErrorUniversalError(err.Error())
}
// 修改数据
newData := *oldData
newData.Balance = req.Balance
newData.Frozen_Amount = req.Frozen_Amount
// 将新数据添加到缓存的底部
err = r.data.cache.RPush(ctx, cacheKey, newData)
if err != nil {
return nil, v1.ErrorUniversalError(err.Error())
}
// 从缓存的头部取出最新的数据
updatedData, err := r.data.cache.LPop(ctx, cacheKey)
if err != nil {
return nil, v1.ErrorUniversalError(err.Error())
}
return updatedData, nil
}
```
这段修改后的代码将数据库更新操作改为了修改缓存的操作。首先从缓存中获取原始数据,然后根据请求更新数据。接下来将更新后的数据添加到缓存的底部,表示最新的数据在列表的末尾。最后通过 LPop 操作从缓存的头部取出最新的数据并返回。
注意:这段代码只涉及缓存的更新操作,并没有包含事务处理、错误处理等完整的逻辑。请根据实际情况进行相应的完善。
阅读全文