如何理解 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. Python如何利用Selenium或者PhantomJS爬取动态网页内容2. 为什么我ping不通我的docker容器呢???3. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题4. 如何解决docker宿主机无法访问容器中的服务?5. javascript - chart.js如何修改某个指定bar的颜色6. angular.js - angularjs的自定义过滤器如何给文字加颜色?7. 请教使用PDO连接MSSQL数据库插入是乱码问题?8. javascript - 关于iscroll的一段代码,希望有人解释9. android - webview 自定义加载进度条10. objective-c - 使用axios 通过vuex mutation修改数据 getter第一次获取失败 第二次成功

网公网安备