
课程咨询: 400-996-5531 / 投诉建议: 400-111-8989
认真做教育 专心促就业
数据库事务的学习与应用是大多数软件开发程序员在学习数据库技术的时候需要重点掌握的一个编程知识点,而本文我们就通过案例分析来简单了解一下,数据库事务概念与特性分析。
什么是事务
事务的定义是:事务是数据库管理系统(DBMS)执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。
事务四大特性
事务包含四大特性,即原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)(ACID)。
原子性(Atomicity)原子性是指对数据库的一系列操作,要么全部成功,要么全部失败,不可能出现部分成功的情况。以转账场景为例,一个账户的余额减少,另一个账户的余额增加,这两个操作一定是同时成功或者同时失败的。
一致性(Consistency)一致性是指数据库的完整性约束没有被破坏,在事务执行前后都是合法的数据状态。这里的一致可以表示数据库自身的约束没有被破坏,比如某些字段的性约束、字段长度约束等等;还可以表示各种实际场景下的业务约束,比如上面转账操作,一个账户减少的金额和另一个账户增加的金额一定是一样的。
隔离性(Isolation)隔离性指的是多个事务彼此之间是完全隔离、互不干扰的。隔离性的终目的也是为了保证一致性。
持久性(Durability)持久性是指只要事务提交成功,那么对数据库做的修改就被永久保存下来了,不可能因为任何原因再回到原来的状态。
事务基本状态
根据事务所处的不同阶段,事务大致可以分为以下5个状态:
活动的(active)当事务对应的数据库操作正在执行过程中,则该事务处于活动状态。
部分提交的(partiallycommitted)当事务中的后一个操作执行完成,但还未将变更刷新到磁盘时,则该事务处于部分提交状态。
失败的(failed)当事务处于活动或者部分提交状态时,由于某些错误导致事务无法继续执行,则事务处于失败状态。
中止的(aborted)当事务处于失败状态,且回滚操作执行完毕,数据恢复到事务执行之前的状态时,则该事务处于中止状态。
提交的(committed)当事务处于部分提交状态,并且将修改过的数据都同步到磁盘之后,此时该事务处于提交状态。
【免责声明】:本内容转载于网络,转载目的在于传递信息。文章内容为作者个人意见,本平台对文中陈述、观点保持中立,不对所包含内容的准确性、可靠性与完整性提供形式地保证。请读者仅作参考。更多内容请加danei0707学习了解。欢迎关注“达内在线”参与分销,赚更多好礼。