事务与锁定-设置事务的隔离级别

/*
可以使用SET TRANSACTION ISOLATION LEVEL语句来设置ORACLE事务隔离级别,其语句结构如下
SET TRANSACTION ISOLATION LEVEL {READ COMMITTED|SERIALIZABLE}
?? -CHENZW 20110417 如何或得当前的TRANSACTION LEVEL?
*/

--1、READ COMMITTED事务隔离级别可以避免脏读(READ COMMITTED隔离级别下,不能看到尚未提交的数据,因此可以避免脏读)
--2、READ COMMITTED事务隔离级别可以产生不可重复读(两次查询结果不一致就是不可重复读,中间update并且commit)
--3、SERIALIZABLE事务隔离级别可以避免幻象数据(保证两次查询的结果集是准确的)
--窗口A
SQL> SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;

事务处理集。

SQL> SELECT * FROM EMP;

     EMPID EMPNAME                  EMPAGE
---------- -------------------- ----------
         1 11111                        27
         3 11111                        28

--窗口B
SQL> insert into emp values(3,'chenzz',28);

已创建 1 行。

SQL> commit;

提交完成。

--窗口A
SQL> select * from emp;

     EMPID EMPNAME                  EMPAGE
---------- -------------------- ----------
         1 11111                        27
         3 11111                        28
SQL> update emp set empname='0000' where empid=1;
update emp set empname='0000' where empid=1
       *
第 1 行出现错误:
ORA-08177: 无法连续访问此事务处理

--4、在READ ONLY事务隔离级别中不能使用DML操作

SQL> set transaction read only;

事务处理集。

SQL> select * from emp;

     EMPID EMPNAME                  EMPAGE
---------- -------------------- ----------
         1 2222                         27
         3 11111                        28
         3 chenzz                       28

SQL> insert into emp values(2,'chen',29);
insert into emp values(2,'chen',29)
            *
第 1 行出现错误:
ORA-01456: 不能在 READ ONLY 事务处理中执行插入/删除/更新操作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值