什么是事务和事务回滚?

什么是事务?

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

在取钱这个过程中,用户账号的余额减少了,但是钱却没有到手。这时候就要用到事务回滚了

事务的四大特性(简称ACID)

原子性(atomicity)
一个事务必须被视为一个不可分割的最小的工作单元,整个事务中的所有操作要么全部提交成功,要么全部失败回滚,对于一个事务来说,不可能只执行其中的一部分操作,这就是职务的原子性。

一致性(consistency)
数据库总是从一个一致性的状态转换到另一个一致性的状态(在前面的例子中,在没有执行取款前,余额总数为5000,在执行完事务后,取出来的钱再加上银行余额的总数跟原来的余额保持一致性原则,否则要么事务中的语句没有执行完,要么执行过程中出现异常)

隔离性(isolation)
通常来说,一个事务所做的修改在最终提交之前,对其他事务是不可见的。

持久性(durability)
一旦事务提交,则其所做的修改会永久保存到数据库(此时即使系统崩溃,修改的数据也不会丢失。)

什么是事务回滚?

事务回滚是指将该事务已经完成对数据库的更新操作撤销,在事务中,每个正确的原子都会被顺序执行,知道遇到错误的原子操作。

什么是回滚?

回滚是删除由一个或多个部分完成的事务执行的更新,为保证应用程序、数据库或系统错误后还原数据库的完整性,需要使用回滚。

回滚包括程序回滚和数据回滚等类型(泛指程序更新失败,返回上一次正确状态行为)
 

你可能感兴趣的