事务的ACID特性

事务是用户定义的一个数据库操作序列,这些操作要么全做,要么全不做,是一个不可分割的工作单位。

事务的4个特性:原子性(A)一致性(C)隔离性(I)持续性(D)

1.原子性

事务是数据库的逻辑工作单位,事务中包括的诸操作要么都做,要么都不做

2.一致性
事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,这些未完成的事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。例如,某公司在银行中有A,B两个账号,现在公司想从A中取出1万,存入B。那么就可以定义一个事务,该事务包含两个操作,第一个操作是从账号A中减去1万,第二个操作是向B中加入1万。这两个操作要么全做,要么全不做。全做或全不做,数据库处于一致性状态。如果只做一个操作,则逻辑上就会发生错误,减少或增加1万元,这时数据库就处于不一致性状态。【可见一致性和原子性密切相关】

3.隔离性

一个事务的执行不能被其他事务干扰。即一个事务的内部操作及使用的数据对其他并发事务是隔离的,并发执行的各个事务之间不能互相干扰

4.持续性

也叫永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久的。接下来的其它操作或故障不应该对其执行结果有任何影响。

事务是恢复和并发控制的基本单位

猜你喜欢

转载自blog.csdn.net/qq_22080999/article/details/81072868