银行转账举例:
转账是生活中常见的操作,比如从A账户转账100元到B账号。站在用户角度而言,这是一个逻辑上的单一操作,然而在数据库系统中,至少会分成两个步骤来完成:
- 将A账户的金额减少100元
- 将B账户的金额增加100元。
在这个过程中可能会出现以下问题:
- 转账操作的第一步执行成功,A账户上的钱减少了100元,但是第二步执行失败或者未执行便发生系统崩溃,导致B账户并没有相应增加100元。
- 转账操作刚完成就发生系统崩溃,系统重启恢复时丢失了崩溃前的转账记录。
- 同时又另一个用户转账给B账户,由于同时对B账户进行操作,导致B账户金额出现异常。
数据库事务
- 数据库事务是构成单一逻辑工作单元的操作集合。
- 是访问并可能操作各种数据项的一个数据库操作序列,这些操作要么全部执行,要么全部不执行。
事务的四大特性(ACID):
- 原子性
事务中的所有操作作为一个整体像原子一样不可分割,要一起执行,不能只执行其中一部分。 - 一致性
事务的执行结果必须使数据库从一个一致性状态到另一