Gorm-事务锁定(二)-天天即时
在使用事务锁定时,需要注意避免死锁的发生。死锁是指两个或多个goroutine在等待对方释放锁定资源的情况下
【资料图】
在使用事务锁定时,需要注意避免死锁的发生。死锁是指两个或多个goroutine在等待对方释放锁定资源的情况下,陷入了一种互相等待的状态。为了避免死锁的发生,我们应该在进行事务锁定时,按照一定的顺序对数据进行加锁。
下面是一个使用事务锁定避免死锁的示例:
package mainimport ( "fmt" "gorm.io/driver/mysql" "gorm.io/gorm")type Account struct { ID uint Balance float64}func main() { dsn := "user:password@tcp(host:port)/database" db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{}) if err != nil { panic(err) } defer db.Close() tx := db.Begin() defer func() { if r := recover(); r != nil { tx.Rollback() } }() var account1, account2 Account if err := tx.Set("gorm:query_option", "FOR UPDATE").Where("id = ?", 1).First(&account1).Error; err != nil { tx.Rollback() panic(err) } if err := tx.Set("gorm:query_option", "FOR UPDATE").Where("id = ?", 2).First(&account2).Error; err != nil { tx.Rollback() panic(err) } if account1.Balance < 100.00 { tx.Rollback() panic("insufficient balance") } account1.Balance -= 100.00 if err := tx.Save(&account1).Error; err != nil { tx.Rollback() panic(err) } account2.Balance += 100.00 if err := tx.Save(&account2).Error; err != nil { tx.Rollback() panic(err) } tx.Commit()}
在这个示例中,我们定义了一个Account结构体,表示账户信息。我们使用Set
方法设置查询选项,并使用Where
方法查询id为1和2的账户信息,并将查询结果存储在变量account1
和account2
中。
我们按照id的大小对两个账户进行加锁,这样可以避免两个goroutine对同一组数据进行加锁,从而避免死锁的发生。接下来,我们检查账户1的余额是否足够,如果不足,则进行回滚操作。
然后,我们分别将账户1的余额减去100元,账户2的余额加上100元,并使用Save
方法将修改后的账户信息写入数据库。
最后,我们使用Commit
方法提交事务。
关键词:
在使用事务锁定时,需要注意避免死锁的发生。死锁是指两个或多个goroutine在等待对方释放锁定资源的情况下
中国光伏行业协会发布2023年3月全国光伏制造行业运行简况。分环节看,2023年3月,全国太阳能级多晶硅产量环
四川省正式印发了《关于加强电气焊作业全链条安全管理的通知》
近日,文化和旅游部办公厅发布关于进一步加强演出市场管理规范演出市场秩序的通知。通知表示,切实规范演出
对于即将到来的五一小长假,你打算怎么过?作为疫情后的第一个五一小长假,相信不少网友都有外出旅游,甚至
26日,记者从洛阳市总工会获悉,河南省总工会发布2023年河南省五一劳动奖章、河南省五一劳动奖状和河南省工
解答:1、蒸饭的好处一般包括补充能量,促进消化。2、米饭是用大米煮的,适合老人、妇女、儿童食用。吃米饭
五一客流量或“爆表”!淄博呼吁:错峰出游,让利于客
第六届数字中国建设成果展览会开幕。 叶秋云 摄中新网福州4月26日电(叶秋云)26日,第六届数字中国建设成
独家资金:今日主力买进前10股
1、倒叙(flashback),是根据表达的需要,把事件的结局或某个最重要、最突出的片段提到文章的前边,然后再从
《电磁兼容技术前沿》第七讲移动通信历史、分析及创新4月19日晚7点,《电磁兼容技术前沿》系列讲座的第七场
可能随着年龄的增大,我们对于自己的保护越来越多,但在旅行途中,我却总是希望可以做一些不敢做的事情。所
买断工龄赔偿金按照员工的工作年限计算。一般来说经济补偿金按劳动者在本单位的工作年限和月工资支付,即工
沈阳14个项目获国家自然科学基金支持---记者4月25日获悉,根据国家自然科学基金委员会《关于批准资助2022年
欢迎来到灵隐塔罗,那今天要和大家分享的是双子座在4月下半月的一个感情事业运势了。因为今天是一个大众占
2023年4月25日晚间,三只松鼠发布2022年度业绩报告,数据显示,2022年三只松鼠营业收入约72 93亿元,同比减
老板电器(002508):经营逐步修复新一轮股权激励落地
企查查APP显示,近日,厦门俱成秋实叁号创业投资合伙企业(有限合伙)成立,法定代表人为厦门俱成春生咨询
国家地震台网官方微博25日消息,中国地震台网正式测定:04月25日23时34分在黄海海域(北纬34 54度,东经122