如何理解 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. Java中main方法里面的参数一定要是String []args吗?2. android - 微信的@功能如何实现的?3. javascript - avalon.js ms-on 事件绑定无效 ?4. docker不显示端口映射呢?5. font-family - 我引入CSS3自定义字体没有效果?6. html5 - canvas中的mousedrag事件,为什么鼠标拖出canvas,然后再次移入canvas,drag事件还触发7. node.js - Nodejs微信开发,视频上传成功,但是不返回给用户8. css - 如何讓圖片像雲一樣的行為?9. html5 - 目前 公司App 嵌入H5页面 做个 手机支付功能 没有做过 所以 请求各位有经验的 给个思路10. css3:flex排版问题

网公网安备