文章详情页
mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里
浏览:93日期: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-compose中volumes的问题2. vim - docker中新的ubuntu12.04镜像,运行vi提示,找不到命名.3. python 多进程 或者 多线程下如何高效的同步数据?4. docker 下面创建的IMAGE 他们的 ID 一样?这个是怎么回事????5. docker-compose 为何找不到配置文件?6. php - 想要远程推送emjio ios端怎么搞 需要怎么配合7. java - Hibernate查询的数据是存放在session中吗?8. 一个走错路的23岁傻小子的提问9. angular.js - node.js中下载的angulae无法引入10. android - 添加multidex后在部分机型上产生anr的问题,该如何解决
排行榜
