什么是事务和事务回滚? |
您所在的位置:网站首页 › 数据库提交命令是什么意思 › 什么是事务和事务回滚? |
数据库理解事务: 为什么要有事务? 事务应用于各种场景,订单系统、银行系统 例如: 小明去某银行取钱,首先有以下几个步骤: 银行卡放入ATM机。,输入密码连接数据库,验证账户密码验证成功,获得用户信息(银行余额:5000)用户输入取款金额,按下确认键(取款:1000)从后台数据库中减掉用户取款金额(剩下余额:4000)ATM机吐出钱用户拿走钱这时候就出现了事务。 什么是事务? 事务是用户定义的一个数据库操作序列,这些操作要么全做,要么全不做,是一个不可分割的工作单位。 在取钱这个过程中,用户账号的余额减少了,但是钱却没有到手。这时候就要用到事务回滚了 事务的四大特性(简称ACID) 原子性(atomicity)一个事务必须被视为一个不可分割的最小的工作单元,整个事务中的所有操作要么全部提交成功,要么全部失败回滚,对于一个事务来说,不可能只执行其中的一部分操作,这就是职务的原子性。 一致性(consistency)数据库总是从一个一致性的状态转换到另一个一致性的状态(在前面的例子中,在没有执行取款前,余额总数为5000,在执行完事务后,取出来的钱再加上银行余额的总数跟原来的余额保持一致性原则,否则要么事务中的语句没有执行完,要么执行过程中出现异常) 隔离性(isolation)通常来说,一个事务所做的修改在最终提交之前,对其他事务是不可见的。 持久性(durability)一旦事务提交,则其所做的修改会永久保存到数据库(此时即使系统崩溃,修改的数据也不会丢失。) 什么是事务回滚? 事务回滚是指将该事务已经完成对数据库的更新操作撤销,在事务中,每个正确的原子都会被顺序执行,知道遇到错误的原子操作。 什么是回滚? 回滚是删除由一个或多个部分完成的事务执行的更新,为保证应用程序、数据库或系统错误后还原数据库的完整性,需要使用回滚。 回滚包括程序回滚和数据回滚等类型(泛指程序更新失败,返回上一次正确状态行为) |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |