mysql中mvcc需要加锁吗-问答-阿里云开发者社区-阿里云

开发者社区> zhywwk> 正文

mysql中mvcc需要加锁吗

2017-02-22 18:53:05 3507 3

前提条件:
1、innodb引擎;
2、隔离级别为RR级别;
3、聚簇索引;
问题:
执行一条: update teacher set name=‘张三’ where id = 2; 该操作在读取阶段, 会把这条记录用X锁锁住呢还是把这条记录复制一份到内存,修改完数据之后, 再通过比较版本号进行更新?

按照我的理解, 既然已经通过对数据增加版本号实现事务, 应该就不再需要对数据加锁了吧, 但是网上很多人说需要next-key对数据锁定, 很疑惑。

取消 提交回答
全部回答(3)
  • 一直没睡醒
    2020-07-01 12:36:55

    我也有这个疑问,你解决了么?

    0 0
  • 五月华斩
    2019-07-17 20:49:48

    这个next-key就是RR级别下才会出现的一个锁。虽然你指定where字句里面有id=2。貌似只要锁定一行记录就行了。其实RR的事务级别就要求不出现幻读。就是要避免你在id=2和id=3之间再插入其他的id=2的记录。所以他就会锁住id=2的next key中间的gap不知道我这么说是否清楚。

    0 0
  • kurten
    2019-07-17 20:49:48

    字符串更新是非原子操作,你可以使用事物处理这个逻辑

    0 0
添加回答
相关问答

17

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 972182浏览量 回答数 17

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 157105浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 333899浏览量 回答数 8

3

回答

请问postgres实时同步数据到mysql数据库有什么好的方案吗?

toni3 2019-06-29 14:55:43 115806浏览量 回答数 3

2

回答

mySQL数据库报错You have an error in your SQL syntax

落地花开啦 2016-02-14 16:09:24 126683浏览量 回答数 2

38

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 256890浏览量 回答数 38

249

回答

阿里云LNAMP(Linux + Nginx + Apache + MySQL + PHP)环境一键安装脚本

云代维 2014-02-14 15:26:06 302627浏览量 回答数 249

97

回答

Redhat/CentOS一键安装web环境全攻略

xiaofanqie 2011-08-11 14:51:38 123223浏览量 回答数 97

2

回答

区域选择帮助

fanyue88888 2012-12-07 15:54:30 204022浏览量 回答数 2

11

回答

【精品问答合集】MongoDB热门问答

李博 bluemind 2019-05-29 16:50:19 120885浏览量 回答数 11
+关注
0
文章
1
问答
推荐问答
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载