现在的位置: 首页 > 综合 > 正文

Oracle不支持脏读,控制事务执行先后顺序的方法

2018年02月07日 ⁄ 综合 ⁄ 共 327字 ⁄ 字号 评论关闭

Oracle目前不支持脏读,对于未提交的数据只能在本进程中查询,

其他进程用户无法查询,这样可能会造成如下问题:

  当A和B两个不同进程的事务同时进行,B事务需要A事务的数据才能

向下执行,也就是说A事务执行成功后B事务才能继续执行,如果A事务没有

执行成功,B事务不能执行。对于这种情况可以采用加锁的方式进行,可以

在两个事务的执行过程中增加排他锁,例如在A事务与B事务中都同时更新

某张表的某一条记录:update ss_install set a=1 where xtsb=1,这样就成功增加了

排他锁。当A事务先执行时,B事务肯定就要等待A事务的完成才能继续执行。

当B事务先执行时,由于产生数据的A事务没有执行,所以也无法执行,B事务

回滚,等待A事务执行完毕,再执行。

抱歉!评论已关闭.