关于事务的四大特性你需要了解清楚

事务四大特性

为什么要用事务

​ 使用事务可以保证数据的一致性和完整性,不会出现数据错误或异常。比如银行转账问题,A往B账户转账1000元,需要三步:1、A往账户B转账1000元 2、A账户余额扣除1000元 3、B账户增加1000元。 整个转账业务必须经过这三步才成立,少哪一步都不行。假设只执行了前两步,那么整个业务就失败(出现数据不一致错误/异常),因而使用一个事务将这三步操作进行控制,可保证数据的一致性和完整性。

四大特性

​ ACID(Atomicity:原子性;Consistency:一致性;Isolation:隔离性;Durability:持久性)

原子性: 事务包含要执行的所有操作要么全部成功,要么全部失败,进行回滚(回滚就是将所有操作还原)。因此事务的操作若成功了就一定对数据库做了改变,若操作失败则不能对数据库有任何影响。

一致性: 指的是事务执行操作的前后,必须保证数据的一致。如同上边转账例子,A向B转账1000元,A账户减少了1000,B账户增加了1000。但是A和B的总数在执行完事务操作前后数据之和都一定是相等的,这就是一致性。

隔离性: 隔离性是为了保证每一个用户在开启并使用事务时,不被其他事务操作所干扰,保持独立的工作不受外界干扰,主要就是防止多个用户对数据库同一张表的访问操作。例如:对于任意两个并发的事务T1和T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么在T1结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。

持久性: 比如一个事务一旦提交以后,那么对数据库表的操作改变就是永久的(比如删除了表中一条记录就永久删除了),即便是数据库系统遇到故障异常情况事务操作仍然会产生改变。

例如我们在使用JDBC操作数据库时,在提交事务方法后,提示用户事务操作完成,当我们程序执行完成直到看到提示后,就可以认定事务以及正确提交,即使这时候数据库出现了问题,也必须要将我们的事务完全执行完成,否则就会造成我们看到提示事务处理完毕,但是数据库因为故障而没有执行事务的重大错误。

img

猜你喜欢

转载自blog.csdn.net/weixin_45496190/article/details/106368157