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

来源:互联网 发布:mac iphone 粘贴板 编辑:程序博客网 时间:2024/06/06 02:52

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事务执行完毕,再执行。

原创粉丝点击