mysql innodb为何会把整个表锁死?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

mysql innodb为何会把整个表锁死?

落地花开啦 2016-02-08 00:30:33 2959

mysql innodb不是行级锁吗?怎么会把整个表锁死?
锁死后把所有的死锁连接kill掉了也没用,再来连接操作那张表的话还是被锁死,只有重启mysql才有用,请问这个是什么原因呢?

云服务器登录 云服务器设置
分享到
取消 提交回答
全部回答(1)
  • 落地花开啦
    2019-07-17 18:39:26

    要实现行级锁, 需要考虑一个问题, 如何才能 判定 一行正在被使用?mysql使用的索引的方式, 这样当其它查询, 修改根据索引找到这一行的时候, 发现索引被上了锁, 就会等待,
    如果查询不是通过索引访问的,那就是 通过简单的遍历所有行得到目标的,那就会给整个表加上锁,
    所以要优化你的数据库表, 用于查询的键要加上索引

    0 0
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

相似问题
最新问题
推荐课程