什么是事务和事务回滚?

什么是事务和事务回滚?数据库理解事务 为什么要有事务 事务应用于各种场景 订单系统 银行系统例如 小明去某银行取钱 首先有以下几个步骤 银行卡放入 ATM 机 输入密码 连接数据库 验证账户密码 验证成功 获得用户信息 银行余额 5000 用户输入取款金额 按下确认键 取款 1000 从后台数据库中减掉用户取款金额 剩下余额 4000 ATM 机吐出钱 用户拿走钱这时候就出现了事务 什么是事务 事务是用户定义的一个数据库操作序列 这些操作要么全做 要么全不做 是一个不可分割的工作单位

数据库理解事务:

为什么要有事务?

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

例如:

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

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

这时候就出现了事务。

什么是事务?

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

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

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

  1. 原子性(atomicity)

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

  1. 一致性(consistency)

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

  1. 隔离性(isolation)

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

  1. 持久性(durability)

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

什么是事务回滚?

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

什么是回滚?

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/178232.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月26日 下午5:44
下一篇 2026年3月26日 下午5:44


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号