数据库 脏读、不可重复读和幻读的区别

本文详细解释了数据库中三种常见的事务问题:脏读、不可重复读和幻读,并提供了通过调整事务隔离级别来解决这些问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.脏读
读取另外一个事务没有提交的数据
解决方法:
把事务的隔离级别调整到READ_COMMITTED

2.不可重复读
同一个事务中 两个相同的查询返回了不同的结果
在一个事务A第一次读取之后 另一个事务B对数据进行了修改并且在A之前提交 此时A第二次读取的数据和第一次不同
解决方法:
把数据库的事务隔离级别调整到REPEATABLE_READ

3.幻读

幻读的重点在于新增或者删除
同样的条件, 第1次和第2次读出来的记录数不一样

事务A先查询了数据 此时事务B又进行了增删操作并且提交 A再进行查询时发现两次查询的记录数不同就像出现了幻觉
解决方法:
数据库事务隔离级别调整到SERIALIZABLE_READ

ps: 之前不太能够分清不可重复读和幻读的区别,二者的主要区别是:

不可重复读的重点是修改 同样的条件, 你读取过的数据, 再次读取出来发现不一样了

而幻读的重点在于新增或者删除,同样的条件, 第1次和第2次读出来的记录数不一样

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值