如何理解 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 - 关于fullpage.js 自动高度失效的问题2. javascript - 移动端粘贴事件,onpaste事件在app中无效,在app中怎么监测到粘贴事件3. 如何使用git对word文档进行版本控制?4. mac连接阿里云docker集群,已经卡了2天了,求问?5. javascript - 你们怎样实现前端分页的?6. javascript - 原生canvas中如何获取到触摸事件的canvas内坐标?7. javascript - Express 和 request 如何代理远程图片?8. python - 在使用Pycharm时经常看到如下的样式,小括号里红色的部分是什么意思呢?9. android - react-native 的headless.js Java API 的代码怎么使用?10. mysql如何判断数据不存在则插入呢?
