数据库事务

数据库在执行并发操作时会出现的问题(事务时数据库并发控制的最小单位)

1.丢失修改

两个事务T1和T2同时读入一个数据并做出修改,这个时候我们不知道最后会保留谁的数据,T1为最后结果的话,T2修改丢失,T2为最后结果的话T1丢失。

2.不可重复读

不可重复读是指事务T1读取数据后,事务T2执行等新操作,导致T1再次读取时与之前不一致,不可重复读有下面三种情况:

(1)T1读取数据库一条数据,T2对这条数据进行了修改,T1再次读取时和之前读取不一致

(2)T1读取了数据库里面一组数据,T2对满足T1条件的数据进行新增,T1再次读取时发现和之前读取结果不一致

(3)与(2)相似若T2对数据进行了删除,也是一样的结果

2和3这两种情况也被称为幻影现象。

3.读‘脏’数据

当T1对数据做出修改,然后T2读取了这些数据,之后T1撤销了修改,那么现在T2就读到了与数据库中不一致的数据,这被称为读‘脏’数据。

2019-7-9增加:数据库事务隔离级别介绍

4.SQL中的事务隔离级别

在SQL标准中将事务隔离级别分成四级:

1)未提交读(Read Uncommitted)只要一个事务中对数据进行了修改就可以被其他事务可见,也就是允许脏读、不可重复读、幻读。

2)已提交读(Read Committed)一个事务中修改了数据要提交后才可被其他事务可见,也就是允许不可重复读、幻读,不允许脏读。

3)可重复读(Repeated  Read)一个事务中每次读取到的数据都是一致的,也就是允许幻读,不允许不可重复读、脏读。

4)序列化( Serializable)所有事务串行执行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值