最近遇到一个问题,两个go协程里要同时更新同一个记录的不同字段(buy和sell)。踩了一天的坑,才找到正确的方式。
首先想到的是使用
o := orm.NewOrm()
·····
o.Update(&rices)
但是发现会出现buy或者sell一个为空的情况。
之后再这里https://www.tizi365.com/archives/131.html看到可以使用这种方式:
// 创建orm对象
o := orm.NewOrm()
// 开始事务
o.Begin()
// 开始执行各种sql语句,更新数据库,这里可以使用beego orm支持任何一种方式操作数据库
// 例如,更新订单状态
_, err1 := o.QueryTable("orders").Filter("Id", 1001).Update(orm.Params{
"Status": "SUCCESS",
})
// 给用户加积分
_, err2 := o.Raw("update users set points = points + ? where username=?", "tizi365", 100).Exec()
// 检测事务执行状态
if err1 != nil || err2 != nil {
// 如果执行失败,回滚事务
o.Rollback()
} else {
// 任务执行成功,提交事务
o.Commit()
}
但是这里有个错误,update本身已经开启事务了,所以要将上面的o.Begin()和 o.Commit(),o.Rollback()几个去掉才可以。