文章详情页
mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里
浏览:245日期: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 - 求css页面解决方案3. Java中main方法里面的参数一定要是String []args吗?4. javascript - webpack构建工具重构代码的流程是怎么样的?5. javascript - 想做一个canvas的触摸画板,但屏幕会在画的时候滚来滚去,如何阻止?6. html5 - 自己的H5页面如何集成支付宝支付7. HTML5表单必填属性设置自定义验证消息?8. mysql 5个left关键 然后再用搜索条件 几千条数据就会卡,如何解决呢9. css - 如何讓圖片像雲一樣的行為?10. javascript - js 多维数组的问题
排行榜

网公网安备