zh286091487 2011-03-21 18:23
浏览 171
已采纳

关于事务执行的疑问

银行转账的例子:
A给B转账,进行转账的时候,系统会首先读取B的余额,然后再更新B的余额,这两个操作封装在一个transfer()的方法中,并加上了事务。
如果这时候C也给B转账,A和C出现同时转账的情况,请问有可能出现什么问题,应该如何解决?(第一个问题)
A和C同时执行transfer()方法,由于套上了事务,根据事务的原子性特点,A和C的transfer()方法是否是一个接着一个执行,还是可能会同时执行?

以上我自己的理解是:
第一个问题,有可能出现A和C都转账了,但是只收到A或C的钱,解决方法,转账的时候锁住B的记录(悲观锁或乐观锁)
第二个问题,两个事务可以并发执行(这里我有疑问,可以并发执行,事务之间就可以交叉执行了,不是破坏了事务原子性的特点吗?还是说原子性只保证事务要么都执行,要么都回滚,不管你两个事务之间是否有并行,并行需要通过锁去解决)

以上为我的观点,希望大家能够帮我解答一下我的疑问,指出我理解错误的地方,以及提出自己的解决方案,谢谢。

  • 写回答

3条回答 默认 最新

  • ppgunjack 2011-03-22 11:52
    关注

    具有公共资源的事务在oracle默认级别的事务中是不可能在涉及重叠的语句处交叉,必然在交叠处等对方放锁才能继续,实际放了交叠的锁,也就意味放了该事务所有其他的锁,commit之后等待的事务才会被通知,也就是说如果A在步骤3阻塞于其他事务Y,那么A无法commit,所以也就无法让B继续
    但事务和事务如果没有重叠资源会可以并行
    但这是单数据库的情况,涉及跨行会更复杂,但是情况可能反而会接近你所说的,这和单数据库不同

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 关于大棚监测的pcb板设计
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)