码迷,mamicode.com
首页 > 数据库 > 详细

Oracle 数据库中不同事务并发访问的问题

时间:2016-12-30 10:48:41      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:而在   关闭   分析   关闭窗口   执行   strong   ima   问控制   现象   

现象

以SQL/Helper为例,打开不同的SQL窗口,对同一个表格进行操作,如下所示。

窗口1:当执行更新任务、紧接着执行查询时获得一组查询结果。结果是对的。

窗口2:而在另外一个SQL查询窗口中执查询,却得到更新前的结果。

当关闭窗口1时,执行窗口2,发现出现正确的更新结果。

 

技术分享

分析

初步分析是数据库的并发访问的问题。当在窗口1中执行更新操作,对数据表格的引用并未有消除,而是在数据库中产生了针对当前事务的副本结果。而窗口2所针对的查询还是旧的更新前的数据库原本。当关闭窗口1后,数据库中的表格被更新,窗口2再次查询,得到正确结果。

这也就是并发的后遗症,也是为了并发访问控制的解决方法的一种现象。如果要做到实时性,那就采用独占资源,排他性访问,等上一个事务结束,后一个事务才允许访问共享资源。

 

Oracle 数据库中不同事务并发访问的问题

标签:而在   关闭   分析   关闭窗口   执行   strong   ima   问控制   现象   

原文地址:http://www.cnblogs.com/arxive/p/6235707.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!