文章详情页
mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里
浏览:193日期: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. 如何解决Centos下Docker服务启动无响应,且输入docker命令无响应?2. docker镜像push报错3. 就一台服务器,mysql数据库想实现自动备份,如何设计?4. docker内创建jenkins访问另一个容器下的服务器问题5. javascript - SuperSlide.js火狐不兼容怎么回事呢6. java - 请问一下genymotion如何连接到内网上一个网站7. Windows系统能否利用Docker使用Ubuntu吗?Ubuntu能使用本机的显卡吗?8. thinkphp出现 mysql too many connections9. mac里的docker如何命令行开启呢?10. javascript - 三目运算符的一些问题
排行榜

网公网安备