时间:2021-05-24
悲观锁
悲观锁,认为数据是悲观的。当我们查询数据的时候加上锁。防止其他线程篡改,直到对方拿到锁,才能修改。
比如,有如下的表。status=1表示可以下单,status=2表示不可以下订单。假如在并发的过程中有两个用户同时查到status=1,那么从逻辑上来说都可以去新增订单,但是会造成商品超卖。
如下例子
CREATE TABLE `goods` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, `status` tinyint(4) DEFAULT NULL, `version` int(11) DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4INSERT INTO demo.goods (id, name, status, version) VALUES (1, 'test', 1, 1);session1执行
set autocommit=0;begin;select *from goods where id=1 and goods.status=1 for update ;update goods set status=2 where id=1;session2执行
begin;select * from goods where id=1 for update;这时候session2是阻塞的,因为锁还在session1,所以锁一直在等待。如果session1一直不提交,那么session2将在一定时间后超时断开连接,并且报
(1205, ‘Lock wait timeout exceeded; try restarting transaction')错误,
具体的锁等待时间可以通过设置innodb_lock_wait_timeout参数进行控制。
如果此时在session1中执行commit 操作,那么session2将得到查询结果,并把锁交给session2。
我们还可以通过
show status like 'innodb_row_lock_%';来进一步查看锁信息。
乐观锁
乐观锁不同于悲观锁,乐观锁是通过自身的程序实现,而不是mySql自身实现。
乐观锁查询的时不上锁,只有在更新的时候检查版本号。
比如我们查询到goods表中version 为1 那么在更新这个表的时候Sql将是
select * from goods where id=1;update goods set status=2,version=version+1 where id=1 and version=1;这里的version是查询时候的版本号,每次更改将会导致version+1。如果版本号不匹配更新将不成功。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文研究的主要是Hibernate悲观锁和乐观锁的全部内容,具体介绍如下。悲观锁悲观锁通常是由数据库机制实现的,在整个过程中把数据锁住(查询时),只要事物不释放
本文实例讲述了mysql悲观锁与乐观锁。分享给大家供大家参考,具体如下:悲观锁与乐观锁是人们定义出来的概念,你可以理解为一种思想,是处理并发资源的常用手段。不要
本文实例讲述了java乐观锁原理与实现。分享给大家供大家参考,具体如下:简单说说乐观锁。乐观锁是相对于悲观锁而言。悲观锁认为,这个线程,发生并发的可能性极大,线
悲观锁、乐观锁简介:悲观锁:同步操作。即用户A在操作某条数据时,为其上锁,限制其他用户操作,用户A操作完成提交事务后其他用户方可操作此数据。乐观锁:使用版本控制
本文实例讲述了PHP+redis实现的悲观锁。分享给大家供大家参考,具体如下:锁机制通常使用的锁分为乐观锁,悲观锁这两种,简单介绍下这两种锁,作为本文的背景知识