Oracle遊標開啟時遇到併發更新

abstractcyj發表於2013-12-13
以前,只知道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

      



 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8520577/viewspace-1063242/,如需轉載,請註明出處,否則將追究法律責任。

相關文章