悲观锁与乐观锁怎么在Mysql中使用

64次阅读
没有评论

共计 1384 个字符,预计需要花费 4 分钟才能阅读完成。

自动写代码机器人,免费开通

悲观锁与乐观锁怎么在 Mysql 中使用?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

悲观锁

悲观锁,认为数据是悲观的。当我们查询数据的时候加上锁。防止其他线程篡改,直到对方拿到锁, 才能修改。

比如,有如下的表。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=utf8mb4
INSERT 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。如果版本号不匹配更新将不成功。

关于悲观锁与乐观锁怎么在 Mysql 中使用问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注丸趣 TV 行业资讯频道了解更多相关知识。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1384字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)