如何理解 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. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!2. debian - docker依赖的aufs-tools源码哪里可以找到啊?3. javascript - vue-cli与后端框架集成config/index.js配置问题4. 浅谈Vue static 静态资源路径 和 style问题5. css - .clearfix:after中为什么设置display: table6. 想写一个python分析统计apache 日志文件的脚本7. 初学 node.js,读取本地html文件报错8. javascript - mock.js可以存储数据吗9. javascript - 请问为什么这个补零函数为什么要放window.onload外面?10. javascript - Userscript 如何阻止内联js中某个函数的执行?

网公网安备