分享

Oracle游标打开时遇到并发更新

 xubin2016 2014-06-09
    以前,只知道Oracle的游标里包含的数据在打开的那一刻已经确定了,但是自己没有实际去验证过。今天做了一次测试,发现情况确实如此

建表:
  create table test_cursor(
     id number,
     c_name varchar2(20)
   );

  insert into test_cursor values(1, 'A'); 
  commit;

   执行一段PL/SQL代码打印出表里的内容:
   declare
    cursor cur_test is select * from test_cursor;
    v_test_cursor test_cursor%rowtype;
     begin
      open cur_test;
      dbms_lock.sleep(60);
      loop
        fetch cur_test into v_test_cursor;
        exit when cur_test%notfound;
        dbms_output.put_line(v_test_cursor.id || ':'||v_test_cursor.c_name);
       end loop;
      close cur_test;
    end;

    在sleep的时候,开启另外一个进程向表里插入几条数据:
    insert into test_cursor values(2, 'B');
     insert into test_cursor values(3, 'C');
     insert into test_cursor values(4, 'D');
    commit;

     等待匿名代码块运行结束,输出是:
     1:A

      



  

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多