文章详情页
				mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里
浏览:172日期:2022-06-15 08:55:29
					
					
					问题描述
mysql for update 锁住了一条或多条数据,或者是整个表 如果事务一直没有提交(比如服务器挂掉了)会不会这表数据一直锁在那里
问题解答
回答1:不会。客户端连接断开后,会自动释放锁。
客户端1
set AUTOCOMMIT = 0;BEGIN;SELECT * FROM articles WHERE id=1 FOR UPDATE ;
客户端2
set AUTOCOMMIT = 0;BEGIN;SELECT * FROM articles WHERE id=1 FOR UPDATE ;
这时,客户端2的查询会卡住。直到客户端1 commit 或 rollback 。但是,如果客户端1直接关闭窗口断开连接,客户端2也能直接拿到锁。说明客户端断开时,会自动释放锁。
那么问题来了,客户端1断开连接后,是自动 rollback 了吗?
相关文章:
1. jpa mysql 如何id自增初始值?2. javascript - angularJS module之间可以通信吗?3. javascript - 怎么才能有效的防止网页被盗?4. javascript - 问一个有趣的问题: 如何将 数字 转成 金额格式5. nginx - 关于vue项目部署到ngnix后出现的问题6. MySQL的SELECT...FOR UPDATE究竟起什么作用7. javascript - vue使用keep-alive不能保持滚动位置问题。8. python - 有一个函数名(字符串形式),如何能够调用这个函数?9. java - mysql查询,这是怎么查询的呢10. javascript - 一个字符串转换成数字,例子就是a="2,322.222",b=’1,211.21’,如何在angualr中执行相减
排行榜
				
 网公网安备
网公网安备