什么是事务和事务回滚?

数据库理解事务:

为什么要有事务?

事务应用于各种场景,订单系统、银行系统

例如:

小明去某银行取钱,首先有以下几个步骤:

  1. 银行卡放入ATM机。,输入密码
  2. 连接数据库,验证账户密码
  3. 验证成功,获得用户信息(银行余额:5000)
  4. 用户输入取款金额,按下确认键(取款:1000)
  5. 从后台数据库中减掉用户取款金额(剩下余额:4000)
  6. ATM机吐出钱
  7. 用户拿走钱

这时候就出现了事务。

什么是事务?

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

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

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

  1. 原子性(atomicity)

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

  1. 一致性(consistency)

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

  1. 隔离性(isolation)

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

  1. 持久性(durability)

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

什么是事务回滚?

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

什么是回滚?

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

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

你可能感兴趣的:(什么是事务和事务回滚?)