发新话题
打印

“顺序事务”与“只读事务”的实际应用

“顺序事务”与“只读事务”的实际应用

“只读事务”是指只允许查询操作,而不允许任何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操作了。

TOP

发新话题