文章详情页
mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里
浏览:99日期: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. 为什么我ping不通我的docker容器呢???2. 服务器端 - 采用nginx做web服务器,C++开发应用程序 出现拒绝连接请求?3. javascript - vue 移动端的input 数字输入优化4. javascript - 有什么兼容性比较好的办法来判断浏览器窗口的类型?5. 关于docker下的nginx压力测试6. javascript - Angular controlller控制域和原生js的关系7. angular.js - Ionic 集成crosswalk后生成的apk在android4.4.2上安装失败???8. python - pandas按照列A和列B分组,将列C求平均数,怎样才能生成一个列A,B,C的dataframe9. HTML5禁止img预览该怎么解决?10. java - 静态属性中的赋值和静态代码块中的赋值有什么区别?
排行榜
