Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103770971
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: Oracle

2008-03-30 23:09:34

来源:赛迪网    作者:林夕

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

阅读(442) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~