悲观锁:事务执行过程中,数据会一直加锁,直至执行完毕,下一个操作这条数据的才可以执行,且拿到数据。
乐观锁:效率比悲观锁要高,主要根据数据记录的版本机制。比如A和B用户同时在操作一条数据,这条数据有version=1,和orderPrice=100字段,现在A要减去50,这个时候会比较version,version=2>1,ok提交成功。B用户要减去20,因为A用户已经commit,B用户并没有获取最新版本号(并行的),这个时候B用户修改完要commit,比较版本号version=2,并不大于当前版本号,更新失败。这时候重新获取下最新金额就ok;
当然这是数据库的解决办法。还有在java中用同步关键字synchronized的
详细:
https://www.cnblogs.com/lr393993507/p/5909804.html
悲观锁和乐观锁的区别
最新推荐文章于 2023-04-23 14:45:04 发布