Oracle 数据库中不同事务并发访问的问题
2016-12-30 09:42
323 查看
现象
以SQL/Helper为例,打开不同的SQL窗口,对同一个表格进行操作,如下所示。
窗口1:当执行更新任务、紧接着执行查询时获得一组查询结果。结果是对的。
窗口2:而在另外一个SQL查询窗口中执查询,却得到更新前的结果。
当关闭窗口1时,执行窗口2,发现出现正确的更新结果。
分析
初步分析是数据库的并发访问的问题。当在窗口1中执行更新操作,对数据表格的引用并未有消除,而是在数据库中产生了针对当前事务的副本结果。而窗口2所针对的查询还是旧的更新前的数据库原本。当关闭窗口1后,数据库中的表格被更新,窗口2再次查询,得到正确结果。
这也就是并发的后遗症,也是为了并发访问控制的解决方法的一种现象。如果要做到实时性,那就采用独占资源,排他性访问,等上一个事务结束,后一个事务才允许访问共享资源。
以SQL/Helper为例,打开不同的SQL窗口,对同一个表格进行操作,如下所示。
窗口1:当执行更新任务、紧接着执行查询时获得一组查询结果。结果是对的。
窗口2:而在另外一个SQL查询窗口中执查询,却得到更新前的结果。
当关闭窗口1时,执行窗口2,发现出现正确的更新结果。
分析
初步分析是数据库的并发访问的问题。当在窗口1中执行更新操作,对数据表格的引用并未有消除,而是在数据库中产生了针对当前事务的副本结果。而窗口2所针对的查询还是旧的更新前的数据库原本。当关闭窗口1后,数据库中的表格被更新,窗口2再次查询,得到正确结果。
这也就是并发的后遗症,也是为了并发访问控制的解决方法的一种现象。如果要做到实时性,那就采用独占资源,排他性访问,等上一个事务结束,后一个事务才允许访问共享资源。
相关文章推荐
- 数据库并发访问、事务与锁的关系
- ORA-02041: 客户数据库未开始一个事务处理 .NET 连接低版本ORACLE时需要注意的问题
- 简单处理K->V缓存失效后高并发访问导致数据库负载急剧上升的问题
- 关于服务器并发访问导致重复写数据库的问题
- Oracle:不同数据库版本导致的Ora-00918问题
- Oracle不同数据库访问DBLink
- oracle用户权限问题造成访问数据库出错
- 数据库事务并发有关问题
- 新装本地ORACLE数据库时访问服务器数据库出问题
- 数据库并发访问、事务与锁、脏读、不可重复读、幻影读
- 多事务同时访问数据库造成事务锁超时问题
- 数据库-并发访问带来的问题
- 关于oracle设置不活动自动断开连接导致java访问数据库时发生异常的问题
- 并发事务下各数据库外部表现实测之二(Oracle篇)
- 利用Memcache解决数据库高并发访问的瓶颈问题
- Oracle不同数据库同步Merge方法,可以部分替代高级复制。对小数据量同步问题不大。转载http://blog.chinaunix.net/u1/55091/showart_430716.html
- memcache解决高并发高访问的数据库瓶颈问题
- hibernate之控制并发访问(事务隔离性问题)
- 查找ORACLE出现“ORA-08177:无法连续访问此事务处理”问题的原因
- db2 数据库访问系统并发问题Reason code = -2029060029