数据库事务

 一.事务概述(TRANSACTION)

    1.1什么是事务

       事务是一个完整的业务逻辑单元,要么一起执行成功,要么全部失败。

    1.2和事务有关的语句只有DML(data manipulation language 数据操作语言)

          包括有insert、update、delete。

    1.3一条语句就可以完成的业务无需使用事务

    1.4实现原理

        a.开启事务机制->多条DML语句->commit/rollback

        b.DML语句执行结果先放入缓存,如果成功则commit提交与数据库文件同步并清除缓存,如果发生错误则回滚事务,清除缓存不同步数据库文件

二.事务四大特征(ACID)

2.1原子性(Atomicity)  事务是工作的最小单元不可再分

2.2隔离性(Isolation)   事务A与事务B不会相互影响,并发执行和串行结果一样

2.3一致性(Consistency) 多条DML同时失败或同时成功

2.4持久性(Durability) 事务一旦提交就修改数据文件,一直存在

三.数据库的隔离性

3.1第一级别-读未提交(read uncommitted)

      对另一事务未提交的事务可以进行读取,即读取另一事务在缓存中的数据,会导致脏读现象,即读取缓存中的“脏数据”。

3.2第二级别-读已提交(read commit)

     只能读取另一事务已提交的数据,并且是动态实时的读取,即不可重复读,在该事件未结束时,读取的数据可以发生变化。

3.3第三级别-可重复读(repeatable read)

     事件未结束时读取数据保持不变,解决不可重复读问题,但会导致幻读。读的是备份数据

3.4第四级别 序列化读/串行化读

    同一时间只允许一个事件执行,解决所有问题,但是效率低,需要事务排队

oracle默认读已提交

mysql默认可重复读

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值