如何理解 MySQL 事务中的不可重复读和幻读问题?
问题描述
如何理解 MySQL 事务中的不可重复读和幻读问题? 或者说 READ COMMIT 和 REPEAT COMMIT 两种隔离性的区别在哪?
问题解答
回答1:刚好学习一下这个,我就粗浅的来说说我的想法:Read Committed(不可重复读):假设事务1读取了一条记录(select user_name from user where user_id = 1),得到user_name = ’456’,事务1暂时没提交。事务2更新了一条记录(update user set user_name = ’123’ where user_id = 1),事务2提交。此时事务1再次select user_name from user where user_id = 1得到了user_name = ’123’,这样就导致事务1在读取同一行数据却得到不同的user_name。这就是所谓的不可以重复读
Repeatable Read(可重复读,会产生幻读):这个跟不可重复读相反,当事务1查询到user_name=’456’时,事务2将user_name更新成’123’并提交,事务1再次查询还是会发现user_name=’456’,这样保证了可重复读。幻读的话就是当事务2插入一条新的数据id为2并提交,事务1由于可重复读的性质,只能在表中查到id为1的数据,如果此时事务1插入id为2的数据则会产生错误,因为此时表中已经有了id为2的数据,但是事务1只看到了id为1的数据。
相关文章:
1. javascript - 打算写一个c++的node图像处理模块,有没有推荐的c++图片处理库?2. java - 同步/异步与阻塞/非阻塞之间的差异具体是什么?3. html5 - 前端面试碰到了一个缓存数据的问题,来论坛上请教一下4. macos - 无法source activate python275. css - 移动端 盒子内加overflow-y:scroll后 字体会变大6. java - butterknife怎么绑定多个view7. css3 让图片变成灰色(filter),但针对IE11浏览器无效8. 运行python程序时出现“应用程序发生异常”的内存错误?9. android - Genymotion 模拟器可以做屏幕适配检测吗?10. python中如何计算t分布的值?

网公网安备