文章详情页
mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里
浏览:230日期: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网络端口映射,没有方便点的操作方法么?2. css3 - 微信前端页面遇到的transition过渡动画的bug3. javascript - vue 父子组件传递数据4. css - input间的间距和文字上下居中5. selenium-selenium-webdriver - python 将当前目录加入到 环境变量6. MYSQL 根据两个字段值查询 但两个值的位置可能是互换的,这个怎么查?7. javascript - ios返回不执行js怎么解决?8. html5上的ICON一般去哪里找?9. css - 有没有什么办法用背景色把部分border给遮挡呢?10. css3 - canvas在IOS8中不兼容。画不出来。
排行榜

网公网安备