事务的 ACID特性及如何保证的

           事务是数据库的一个非常重要的特性,包含ACID四大特性,下面详细介绍一下这四大特性及背后是如何保证的

           原子性(Atomic) 事务里面的所有操作要么全部成功,要么全部失败。靠undo log来保证,每条sql执行时会在undo log里面记录一条相反的日志,如果要回滚就执行undo log里面的回滚sql来进行回滚

           一致性(Consistence) 这里的一致性指的是数据库约束的一致性及业务数据的一致性。例如转账事务,一个人转出了500,那么另外一个人要收到500,保证最终的状态是一致的,一致性是原子性,隔离性,持久性三个特性共同来保证的。

          隔离性(Isolation)   隔离性指的是不同事务之间相互的隔离范围。按照读未提交,读已提交,可重复读,串形化这四种隔离级别来控制,默认是可重复读。由数据库的锁机制及MVCC来保证

         持久性(Durable). 持久性指的是事务一旦提交,那么就应该永久的状态,不会因数据库宕机等意外情况而丢失事务操作的数据。它是通过redo log来保证的。当事务操作在Buffer Pool内存中进行的时候,同时会写入redo log,如果数据库重启或者宕机了会执行 redo log 来保证事务操作不会丢失。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值