ORACLE中TRANSACTION ISOLATION的理解

iefus 2011-01-26 05:27:05
关于oracle的隔离级别是不是可以这样理解

新建一个连接,生成一个session
在这个session中,默认的隔离级别是read committed
然后可以根据自己需要,更改隔离级别

每一个session中,隔离级别的更改互不影响
...全文
316 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
xman_78tom 2011-01-26
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 iefus 的回复:]

引用 1 楼 xman_78tom 的回复:
是的。

在会话中可通过 alter session set isolation_level=... 修改当前会话的事务隔离级别;
可以通过 set transaction isolation level ... 设置当前事务的隔离级别。


这两种隔离级别有什么不同啊
会话的隔离级别随着session关闭就没了
当前事务的隔离级别……
[/Quote]

set transaction 设置的隔离级别只对当前事务有效,事务结束,级别丢失。
lxyzxq2008 2011-01-26
  • 打赏
  • 举报
回复

一.事务的概念

  事务可以看作是由对数据库的若干操作组成的一个单元,这些操作要么都完成,要么都取消,从而保证数据满足一致性的要求。事务的一个典型例子是银 行中的转帐操作,帐户A把一定数量的款项转到帐户B上,这个操作包括两个步骤,一个是从帐户A上把存款减去一定数量,二是在帐户B上把存款加上相同的数 量。这两个步骤显然要么都完成,要么都取消,否则银行就会受损失。显然,这个转帐操作中的两个步骤就构成一个事务。

  数据库中的事务还有如下ACID特征。

  ACID分别是四个英文单词的首写字母,这四个英文单词是Atomicity、Consistency、Isolation、Durability,分别翻译为原子性、一致性、隔离性、持久性。

  原子性:指事务中的操作,或者都完成,或者都取消。

  一致性:指事务中的操作保证数据库中的数据不会出现逻辑上不一致的情况,一致性一般会隐含的包括在其他属性之中。

  隔离性:指当前的事务与其他未完成的事务是隔离的。在不同的隔离级别下,事务的读取操作,可以得到的结果是不同的。

  持久性:指对事务发出COMMIT命令后,即使这时发生系统故障,事务的效果也被持久化了。与此相反的是,当在事务执行过程中,系统发生故障,则事务的操作都被回滚,即数据库回到事务开始之前的状态。

  对数据库中的数据修改都是在内存中完成的,这些修改的结果可能已经写到硬盘也可能没有写到硬盘,如果在操作过程中,发生断电或系统错误等故障, 数据库可以保证未结束的事务对数据库的数据修改结果即使已经写入磁盘,在下次数据库启动后也会被全部撤销;而对于结束的事务,即使其修改的结果还未写入磁 盘,在数据库下次启动后会通过事务日志中的记录进行“重做”,即把丢失的数据修改结果重新生成,并写入磁盘,从而保证结束事务对数据修改的永久化。这样也 保证了事务中的操作要么全部完成,要么全部撤销。

  二.事务设置及类型的区别

  在SQL Server中有三种事务类型,分别是:隐式事务、显式事务、自动提交事务,缺省为自动提交。

  自动提交,是指对于用户发出的每条SQL语句,SQL Server都会自动开始一个事务,并且在执行后自动进行提交操作来完成这个事务,也可以说在这种事务模式下,一个SQL语句就是一个事务。

  显式事务,是指在自动提交模式下以Begin Transaction开始一个事务,以Commit或Rollback结束一个事务,以Commit结束事务是把事务中的修改永久化,即使这时发生断电这样的故障。例如下面是SQL Server中的一个显式事务的例子。

  Begin TranUpdate emp Set ename=’Smith’ Where empno=7369

  Insert Into dept Values(60,’HR’,’GZh’)Commit

  隐式事务,是指在当前会话中用Set Implicit_Transactions On命令设置的事务类型,这时任何DML语句(Delete、Update、Insert)都会开始一个事务,而事务的结束也是用Commit或Rollback。

  在Oracle中没有SQL Server的这些事务类型,缺省情况下任何一个DML语句都会开始一个事务,直到用户发出Commit或Rollback操作,这个事务才会结束,这与SQL Server的隐式事务模式相似。

  三.事务隔离级别

  在SQL92标准中,事务隔离级别分为四种,分别为:Read Uncommitted、Read Committed、Read Repeatable、Serializable,其中Read Uncommitted与Read Committed为语句级别的,而Read Repeatable与Serializable是针对事务级别的。

  在Oracle和SQL Server中设置事务隔离级别的语句是相同的,都使用SQL92标准语法,即:

  Set Transaction Isolation Level Read Committed

  上面示例中的Read Committed可以被替换为其他三种隔离级别中的任意一种。

  1.SQL Server中的隔离级别及实现机制

  在SQL Server中提供了所有这四种隔离级别。

  下面我们讨论在SQL Server中,这几种隔离级别的含义及其实现方式。

  Read Uncommitted:一个会话可以读取其他事务未提交的更新结果,如果这个事务最后以回滚结束,这时的读取结果就可能是错误的,所以多数的数据库应用都不会使用这种隔离级别。

  Read Committed:这是SQL Server的缺省隔离级别,设置为这种隔离级别的事务只能读取其他事务已经提交的更新结果,否则,发生等待,但是其他会话可以修改这个事务中被读取的记 录,而不必等待事务结束,显然,在这种隔离级别下,一个事务中的两个相同的读取操作,其结果可能不同。

  Read Repeatable:在一个事务中,如果在两次相同条件的读取操作之间没有添加记录的操作,也没有其他更新操作导致在这个查询条件下记录数增多,则两次 读取结果相同。换句话说,就是在一个事务中第一次读取的记录保证不会在这个事务期间发生改变。SQL Server是通过在整个事务期间给读取的记录加锁实现这种隔离级别的,这样,在这个事务结束前,其他会话不能修改事务中读取的记录,而只能等待事务结 束,但是SQL Server不会阻碍其他会话向表中添加记录,也不阻碍其他会话修改其他记录。

  Serializable:在一个事务中,读取操作的结果是在这个事务开始之前其他事务就已经提交的记录,SQL Server通过在整个事务期间给表加锁实现这种隔离级别。在这种隔离级别下,对这个表的所有DML操作都是不允许的,即要等待事务结束,这样就保证了在 一个事务中的两次读取操作的结果肯定是相同的。

  2.Oracle中的隔离级别及实现机制

  在Oracle中,没有Read Uncommitted及Repeatable Read隔离级别,这样在Oracle中不允许一个会话读取其他事务未提交的数据修改结果,从而避免了由于事务回滚发生的读取错误。Oracle中的 Read Committed和Serializable级别,其含义与SQL Server类似,但是实现方式却大不一样。

  在Oracle中,存在所谓的回滚段(Oracle9i之前版本)或撤销段(Oracle9i版本),Oracle在修改数据记录时,会把这些 记录被修改之前的结果存入回滚段或撤销段中,就是因为这种机制,Oracle对于事务隔离级别的实现与SQL Server截然不同。在Oracle中,读取操作不会阻碍更新操作,更新操作也不会阻碍读取操作,这样在Oracle中的各种隔离级别下,读取操作都不 会等待更新事务结束,更新操作也不会因为另一个事务中的读取操作而发生等待,这也是Oracle事务处理的一个优势所在。

  Oracle缺省的设置是Read Committed隔离级别(也称为语句级别的隔离),在这种隔离级别下,如果一个事务正在对某个表进行DML操作,而这时另外一个会话对这个表的记录进 行读取操作,则Oracle会去读取回滚段或撤销段中存放的更新之前的记录,而不会象SQL Server一样等待更新事务的结束。

  在Serializable隔离级别(也称为事务级别的隔离),事务中的读取操作只能读取这个事务开始之前已经提交的数据结果。如果在读取时, 其他事务正在对记录进行修改,则Oracle就会在回滚段或撤销段中去寻找对应的原来未经更改的记录(而且是在读取操作所在的事务开始之前存放于回滚段或 撤销段的记录),这时读取操作也不会因为相应记录被更新而等待。

ps:自己也学习下:
lxyzxq2008 2011-01-26
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 iefus 的回复:]

引用 1 楼 xman_78tom 的回复:
是的。

在会话中可通过 alter session set isolation_level=... 修改当前会话的事务隔离级别;
可以通过 set transaction isolation level ... 设置当前事务的隔离级别。


这两种隔离级别有什么不同啊
会话的隔离级别随着session关闭就没了
当前事务的隔离级别……
[/Quote]当前会话高于当前事务,当前事务存在于当前会话中
lxyzxq2008 2011-01-26
  • 打赏
  • 举报
回复
好像是的,不常用,一般都默认
iefus 2011-01-26
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 xman_78tom 的回复:]
是的。

在会话中可通过 alter session set isolation_level=... 修改当前会话的事务隔离级别;
可以通过 set transaction isolation level ... 设置当前事务的隔离级别。
[/Quote]

这两种隔离级别有什么不同啊
会话的隔离级别随着session关闭就没了
当前事务的隔离级别呢,随着当前事务结束,就没了么
xman_78tom 2011-01-26
  • 打赏
  • 举报
回复
是的。

在会话中可通过 alter session set isolation_level=... 修改当前会话的事务隔离级别;
可以通过 set transaction isolation level ... 设置当前事务的隔离级别。

17,078

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧