一、什么是事务
事务是程序中一系列逻辑相关的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消。
例如:
我们写的一个方法中有多次增删改数据库的操作,事务就是要是整个方法不出问题,所有的增删改按照我们写的一一执行。
如果缺少的事务的管理,方法执行一半,抛出的错误,则出错代码之前的增删改操作抖操作成功了,之后的又因为报错还没有执行到,导致整段代码没有按照我们预先设计的执行操作数据库。就会出问题。
有了事务以后,要么这个方法整体执行成功,要么失败就和没执行这个方法一样。执行失败不会对后续产生影响。
换句话说,事务就是不成功则成仁,没有成功一半的说法。
二、数据库事务的ACID特性
事务具有四个特征:原子性( Atomicity )、一致性( Consistency )、隔离性( Isolation )和持久性( Durability )。这四个特性简称为 ACID 特性。
1 、原子性
事务是数据库的逻辑工作单位,不可分割,事务中包含的各操作要么都做,要么都不做。
2 、一致性
事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是 不一致的状态。
3 、隔离性
一个事务的执行不能其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。 事务的隔离级别有4级。
4 、持续性
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的,不能回滚。接下来的其它操作或故障不应该对其执行结果有任何影响。