文章详情页
mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里
浏览:115日期: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. docker容器呢SSH为什么连不通呢?2. docker api 开发的端口怎么获取?3. docker网络端口映射,没有方便点的操作方法么?4. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””5. python - from ..xxxx import xxxx到底是什么意思呢?6. nignx - docker内nginx 80端口被占用7. debian - docker依赖的aufs-tools源码哪里可以找到啊?8. ddos - apache日志很多其它网址,什么情况?9. 请教各位大佬,浏览器点 提交实例为什么没有反应10. angular.js - ng-grid 和tabset一起用时,grid width默认特别小
排行榜
