如何理解 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 - SuperSlide.js火狐不兼容怎么回事呢2. 就一台服务器,mysql数据库想实现自动备份,如何设计?3. python - 如何用pandas处理分钟数据变成小时线?4. android - webview 自定义加载进度条5. javascript - mongoose对查询结果的排序问题6. java - 哪位大神做过考勤打卡定位功能?请大神指点7. javascript - JAVA后台怎么设置表头的宽度8. css - 为什么video不能填满整个父级div?底部有黑边?9. java - android代码重构:如何把app设置里的头像UI做成通用的?10. mysql - 删除数据库中的数据,但是表结构保留

网公网安备