Oracle Database Transaction Isolation Levels 事务隔离级别
Overview of Oracle Database Transaction Isolation Levels
- Oracle 数据库提供如下事务隔离级别:
- 已提交读隔离级别
- 可串行化隔离级别
- 只读隔离级别
Read Committed Isolation Level
- 在(默认的)已提交读隔离级别中,事务中执行的每个查询,仅看到在查询开始之前提交的数据,而不是事务开始之前提交的数据。这一隔离级别适合于几乎不可能发生事务冲突的数据库环境
- 已提交读事务中的查询可以避免读取在查询过程中所提交的数据。例如,如果一个查询正扫描到一个百万行表的一半,而另一个不同的事务对第 950000 行提交了一个更新,但当查询读到第 950000 行时,它并不能看见这个变化。然而,由于数据库不会阻止其它事务修改一个查询所读取的数据,其他事务可能会在查询执行期间更改数据。因此,两次运行相同查询的事务可能会出现模糊读和幻想读现象
Read Consistency in the Read Committed Isolation Level
- 为每个查询提供一个一致的结果集,保证数据一致性,无需用户采取任何行动。对于隐含的查询(如在一个 UPDATE 语句中的 WHERE 子句),也同样可以保证其一致的结果集。但是,在隐式查询中的每个语句不会看到 DML 语句本身所做的更改,只能看到更改之前所存在的数据
- 如果 SELECT 列表中包含一个 PL/SQL 函数,则数据库在该 PL/SQL 函数代码内运行的 SQL 的级别(而不是在父 SQL 级别)上应用语句级别读一致性。例如,一个函数可能会访问某个表,其数据被另一个用户更改并提交。每次运行函数中的 SELECT 语句,都会建立一个新的读一致性快照
Conflicting Writes in Read Committed Transactions
- 在一个已提交读事务中,当事务尝试更改由另一个未提交并发事务(有时称为阻塞事务)所更新的行时,会发生写冲突。读提交事务将等待阻塞事务结束并释放其行锁。有两个选项如下所示:
- 如果阻塞事务回滚,正在等待的事务将继续并更改之前被锁定的行,就像另一个事务从未存在一样
- 如果阻塞事务提交并释放了锁,则正在等待的事务将对这个刚被更新的行继续其预定更新
- 表 9-2 显示了一个可能是可串行化的或已提交读的事务 1,如何与另一个已提交读的事务 2 进行交互。表 9-2 显示了一个称为丢失更新(lost update)的典型情况。事务 1 所作的更新不能在表中反映出来,即使事务 1 已经提交它。制定一项策略以处理丢失更新是应用程序开发的一个重要部分



Serializable Isolation Level
- 在可串行化隔离级别,事务只看到自事务开始以来(而不是自查询以来)该事务本身所提交的更改。可串行化事务运行在使其看起来好像没有其他用户在修改数据库中的数据的环境中
- 可串行化隔离适合如下环境:
- 大型数据库中只更新少数几行的短事务
- 两个并发事务将修改相同的行的可能性相对较低
- 较长时间运行的事务主要是只读事务
- 在可串行化隔离级别,在语句级别所获得的读取一致性通常延伸到整个事务范围。当重新读取在同一事务中之前读取的任何行时,保证结果相同。可以保证任何查询在该事务的持续期间返回相同的结果,因此其他事务所做的更改是不可见的,无论该查询已运行了多长时间。可串行化事务不会遇到脏读、模糊读取、幻读
- Oracle 数据库允许可串行化事务修改行,只要可串行化事务开始时,由其它事务对行所做的更改已提交。当一个可串行化事务试图更新或删除某数据,而该数据在串行化事务开始后被另一个不同的事务更改并提交,则数据库将生成一个错误:
ORA-08177: Cannot serialize access for this transaction - 当可串行化事务失败产生错误时,应用程序可以采取以下几种:
- Commit the work executed to that point
- 也许要先回滚到事务中之前建立的某保存点,然后执行一些其他额外 的(不同)语句
- 回滚整个事务
- 表 9-3 显示了一个可串行化事务与其它事务之间的交互。如果可串行化事务不会尝试更改由另一个事务在该可串行化事务开始后所提交的行,就可以避免可串行化访问问题




Read-Only Isolation Level
- 只读隔离级别类似于可串行化隔离级别,但只读事务不允许数据在事务中被修改,除非该用户是 SYS。因此,只读事务不会受到 ORA-08177 错误的影响。只读事务可用于生成报表,其内容必须与事务开始时保持一致
- Oracle 数据库通过从 undo 段中重建数据,来实现读取一致性。因为 undo 段是循环使用的,数据库可以覆盖 undo 数据。长时间运行的报表可能有一定的风险,读一致性所需要的 undo 数据可能已被一个不同的事务重用,并抛出快照太旧(snapshot too old)错误。设置一个 undo 保留期,即在旧数据被覆盖之前,数据库尝试保留 undo 数据的最短时间,以期避免这一问题
官方文档的参考链接 http://docs.oracle.com/cd/E11882_01/server.112/e40540/consist.htm#CNCPT621
Oracle Database Transaction Isolation Levels 事务隔离级别的更多相关文章
- 14.3.2.1 Transaction Isolation Levels 事务隔离级别
14.3.2 InnoDB Transaction Model InnoDB 事务模型 14.3.2.1 Transaction Isolation Levels 事务隔离级别 14.3.2.2 au ...
- 事务,Oracle,MySQL及Spring事务隔离级别
一.什么是事务: 事务逻辑上的一组操作,组成这组操作的各个逻辑单元,要么一起成功,要么一起失败. 二.事务特性(4种): 原子性 (atomicity):强调事务的不可分割:一致性 (consiste ...
- Java面试题之Oracle 支持哪三种事务隔离级别
Oracle 支持三种事务隔离级别: 1.读已提交:(默认) 2.串行化: 3.只读模式
- 一文讲清楚MySQL事务隔离级别和实现原理,开发人员必备知识点
经常提到数据库的事务,那你知道数据库还有事务隔离的说法吗,事务隔离还有隔离级别,那什么是事务隔离,隔离级别又是什么呢?本文就帮大家梳理一下. MySQL 事务 本文所说的 MySQL 事务都是指在 I ...
- mysql事务隔离级别详解和实战
A事务做了操作 没有提交 对B事务来说 就等于没做 获取的都是之前的数据 但是 在A事务中查询的话 查到的都是操作之后的数据 没有提交的数据只有自己看得到,并没有update到数据库. 查看InnoD ...
- mysql事务隔离级别设置
设置innodb的事务级别方法是:set 作用域 transaction isolation level 事务隔离级别: 若没有输入作用域直接修改transaction isolation,显示修改成 ...
- 事务的隔离级别和mysql事务隔离级别修改
A事务做了操作 没有提交 对B事务来说 就等于没做 获取的都是之前的数据 但是 在A事务中查询的话 查到的都是操作之后的数据 没有提交的数据只有自己看得到,并没有update到数据库. 查看InnoD ...
- 面试突击61:说一下MySQL事务隔离级别?
MySQL 事务隔离级别是为了解决并发事务互相干扰的问题的,MySQL 事务隔离级别总共有以下 4 种: READ UNCOMMITTED:读未提交. READ COMMITTED:读已提交. REP ...
- 数据库事务隔离级ORACLE数据库事务隔离级别介绍
本文系转载,原文地址:http://singo107.iteye.com/blog/1175084 数据库事务的隔离级别有4个,由低到高依次为Read uncommitted.Read committ ...
随机推荐
- poj1797 Heavy Transportation Dijkstra算法的简单应用
题目链接:http://poj.org/problem?id=1797 题目就是求所有可达路径的其中的最小值边权的最大值 即对于每一条能够到达的路径,其必然有其最小的承载(其实也就是他们自身的最大的承 ...
- 深入理解IOC
1. IoC理论的背景 我们都知道,在采用面向对象方法设计的软件系统中,它的底层实现都是由N个对象组成的,所有的对象通过彼此的合作,最终实现系统的业务逻辑. 图1:软件系统中耦合的对象 如果我们打开机 ...
- ER模型的学习
(计应154兰家才)在建立表后开始了学习的第一步,了解数据库的基本知识,就以建立bbs论坛为标准学习er模型,首先建立了4个表分别是BBSReply,BBSSection,BBSTopic,BBSUs ...
- 分布式缓存技术redis学习—— 深入理解Spring Redis的使用
关于spring redis框架的使用,网上的例子很多很多.但是在自己最近一段时间的使用中,发现这些教程都是入门教程,包括很多的使用方法,与spring redis丰富的api大相径庭,真是浪费了这么 ...
- React-Router 4 的新玩意儿
上一个项目用的还是 2.6.1,转眼的功夫 4.0 都发布了,API 变化实在有点大,2.X那套东西不顶用了,老老实实重新看一遍文档,其中有几点需要注意的,拿出来说一说. 本文只讨论针对浏览器的应用, ...
- 用java读写ini配置文件
本文转载地址: http://www.blogjava.net/silvernapoleon/archive/2006/08/07/62222.html import java.io.Bu ...
- 简单VR照片 使用陀螺仪、姿态角(Roll、Pitch、Yaw )、四元数
最近在做一个类似VR照片的demo,跟全景图片也很像,只是VR照片与全景720度显示,我只做了180度.但我发现他们实现的原理有一丝相似,希望可以给一些想入行AR.VR的朋友一些提示吧. ...
- php笔记一
一.Login登陆验证步骤: 1.赋值,用$_POST将id和password传递给loginProcess.php登陆验证页面. 2.建立数据库连接 $conn=mysql_connect($hos ...
- Coursera 机器学习笔记(一)
主要是第一二周内容 机器学习概要 机器学习是什么? 生活在信息时代的我们,其实时时刻刻都离不开机器学习算法.比如日常使用的搜索引擎就涉及到很多学习算法. Arthur Samuel 给出第一个定义.他 ...
- Vue基础概念,学习环境等
前提: 你已有 HTML.CSS 和 JavaScript 中级前端知识. 概念: Vue.js(读音 /vjuː/,类似于 view) 是一套构建用户界面的渐进式框架.与其他重量级框架不同的是,Vu ...