什么是脏读?幻读?不可重复读?产生原因?

1.脏读

        脏读(Dirty Read),是指一个事务读取了另一个事务未提交的数据,并在在这个读取的脏数据上进行操作。

A事务读取了B事务尚未提交的更改数据,并在这个读取的脏数据上进行操作。如果这时B事务恰巧进行了回滚事务,那么A事务读取的事务是不被承认的;

案例:取款事务和转账事务:

导致账户余额差错;

2.幻读

        幻读(Phantom Read),是指事务读取某个范围的数据时, 因为其他事务的操作导致前后两次读取的结果不一致。

案例:

 到时前后两次范围数据统计查询结果不一致;

3.不可重复读

        不可重复读(Unrepeatable Read),是指A事务读取到了B事务已经提交的更改数据,在同个时间段内,前后两次查询的结果不一致;

案例:转账取款

4.产生原因:

        事务并发异常会导致产生脏读,幻读,不可重复读的现象

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值