数据库事务及隔离级别

本文探讨了数据库事务的重要性和其四个特性:原子性、一致性、隔离性和持久性。介绍了在不考虑事务隔离情况下,转账操作可能出现的脏读、不可重读和幻读问题,并详细解释了这三种问题的实例。接着,文章阐述了事务的四种隔离级别——读未提交、读已提交、重复读和串行化,以及它们如何解决并发操作时的问题。最后指出,不同隔离级别在避免并发问题的同时,对系统性能的影响也各不相同。
摘要由CSDN通过智能技术生成

银行转账举例:

转账是生活中常见的操作,比如从A账户转账100元到B账号。站在用户角度而言,这是一个逻辑上的单一操作,然而在数据库系统中,至少会分成两个步骤来完成:

  1. 将A账户的金额减少100元
  2. 将B账户的金额增加100元。
    在这里插入图片描述

在这个过程中可能会出现以下问题:

  1. 转账操作的第一步执行成功,A账户上的钱减少了100元,但是第二步执行失败或者未执行便发生系统崩溃,导致B账户并没有相应增加100元。
  2. 转账操作刚完成就发生系统崩溃,系统重启恢复时丢失了崩溃前的转账记录。
  3. 同时又另一个用户转账给B账户,由于同时对B账户进行操作,导致B账户金额出现异常。

数据库事务
  1. 数据库事务是构成单一逻辑工作单元的操作集合。
  2. 是访问并可能操作各种数据项的一个数据库操作序列,这些操作要么全部执行,要么全部不执行。

事务的四大特性(ACID):

  1. 原子性
    事务中的所有操作作为一个整体像原子一样不可分割,要一起执行,不能只执行其中一部分。
  2. 一致性
    事务的执行结果必须使数据库从一个一致性状态到另一
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值