以前,只知道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 |
|