只读事务是指只允许查询操作,而不允许任何dml操作的事务。如有2个session,sessionA及session B.当sessionA设置了只读事务后,即使session B对sessionA所查询信息做了修改,而sessionA所查询的仍然是修改前的值。
Time 1:
Session A:
scott@KENNY> set transaction read only;
Transaction set.
Time2:
Session B:
scott@KENNY> update emp set sal=4000 where ename='SMITH';
1 row updated.
scott@KENNY> commit;
Commit complete.
Time 3:
Session A:
scott@KENNY> select * from emp where ename='SMITH';
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- ---------- --------- ---------- --------- ---------- ---------- ----------
7369 SMITH CLERK 7902 17-DEC-80 2000 20
可以看到,在Session A下所查到的值仍然是更改前的sal:2000。
=================================================
在只读事务中,由于无法继续执行dml操作,因此,可以设置顺序事务使之enable:
sql>set transaction isolation level serializable;
这样,就可以在session中继续dml操作了。
[@more@]