“顺序事务”与“只读事务”的实际应用
“只读事务”是指只允许查询操作,而不允许任何dml操作的事务。例如有两个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操作了。