ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2020-05-28 12:36:24  阅读:235  来源: 互联网

标签:转账 事务 数据库 特性 T1 四大 操作 1000


事务四大特性

为什么要用事务

​ 使用事务可以保证数据的一致性和完整性,不会出现数据错误或异常。比如银行转账问题,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

标签:转账,事务,数据库,特性,T1,四大,操作,1000
来源: https://blog.csdn.net/weixin_45496190/article/details/106368157

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有