Oracle PLSQL之cursor取得是open时的数据

来源:这里教程网 时间:2026-02-27 11:44:14 作者:

当我们定义了一个很复杂的cursor,这个cursor需要执行很长时间,在这个cursor执行的过程中,其它用户又修改了该cursor所引用的表

当我们定义了一个很复杂的cursor,这个cursor需要执行很长时间,,在这个cursor执行的过程中,其它用户又修改了该cursor所引用的表的数据时,cursor得到的是修改前还是修改后的数据呢? 

答案是cursor得到的始终是cursor在open时的数据,接下来我们将通过一个小实验来验证。

首先,session1执行以下匿名块,该匿名块通过cursor取得t1表的所有数据,不过在open cursor后将暂停30秒,在这30秒中我们将在session2中删除t1表的所有数据: 

相关推荐