咨询热线:15811653920

2009-2017

我们一直走在国际设计的前沿,追求与研究从未停止

我的位置:首页 > 学院 > 建站知识

什么是事务和事务回滚?

数据库理解事务:

为什么要有事务?

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


例如:

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


银行卡放入ATM机。,输入密码

连接数据库,验证账户密码

验证成功,获得用户信息(银行余额:5000)

用户输入取款金额,按下确认键(取款:1000)

从后台数据库中减掉用户取款金额(剩下余额:4000)

ATM机吐出钱

用户拿走钱

这时候就出现了事务。


什么是事务?

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

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


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

原子性(atomicity)

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


一致性(consistency)

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


隔离性(isolation)

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


持久性(durability)

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


什么是事务回滚?

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


什么是回滚?

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


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

想了解更多,请访问齐创互联,需要网站建设,浏览快速建站模板快速建站
点击在线客服联系客服,联系电话:15811653920 联系人: 丁生.


感谢您关注我们,如果您有建站需求,请与我们取得联系。
扫一扫上面的二维码图案,加我微信
扫一扫上面的二维码图案,加我微信
咨询直线:15811653920 丁生

建站模板

Web Templates

建站龙头,低价保证,贴心服务

权威认证建站龙头企业,合理定价,实现与客户的长期合作,30万家企业级用户优选!