文章详情页
mysql for update 如果事务一直没有提交会不会这表数据一直锁在那里
浏览:215日期: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. html5 - 图片一般一怎么的形式存放在服务器中的?2. 网页爬虫 - python 爬取网站 并解析非json内容3. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!4. node.js - mongodb查找子对象的名称为某个值的对象的方法5. 百度地图api - Android 百度地图 集成了定位,导航 相互的jar包有冲突?6. node.js - express框架,设置浏览器从缓存中读取静态文件,只有js从缓存中读取了,css还有一些图片为何没有从缓存中读取?7. 浅谈Vue static 静态资源路径 和 style问题8. vue.js - vue-router开启HTML5的history模式后nginx配置9. python - flask post提交timestamp不能作为参数,这是为什么?10. javascript - 回调函数和闭包的关系
排行榜

网公网安备