博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle --- 事务隔离级别
阅读量:4106 次
发布时间:2019-05-25

本文共 823 字,大约阅读时间需要 2 分钟。

隔离级别(isolation level),是指事务与事务之间的隔离程度。

 

显然,事务隔离程度越高,并发性越差、性能越低;事务隔离程度越低,并发性越强、性能越高。

 

ANSI/ISO SQL92标准中定义了4种事务隔离级别:

 

1.       序列化(serializable)

最高隔离级别。系统中所有的事务都是一个接一个执行的。因此也就不会发生任何事务之间的冲突问题。

 

2.       可重复读(repeatable read)

一个事务所读取的数据记录不允许被其他事务所修改。

 

3.       读已提交(read committed)

该级别允许其他事务修改当前事务所读取的数据记录,并且那个事务提交之后,当前事务可以看到修改后的数据。

 

4.       读未提交(read uncommitted)

该级别允许其他事务修改当前事务所读取的数据记录,并且那个事务尚未提交时,当前事务就可以看到修改后的数据。即允许脏读。

 

事务隔离级别不同,执行一条数据库查询,得到的结果很可能让你感到意外,下面是这些情况的总结:

 

1.       脏读

读取了其他事务还没有提交的数据。

 

2.       不可重复读

当前事务已经读取的数据记录,被其他事务修改或删除。

 

3.       幻影读

其他事务插入了新的数据,当前事务以相同的查询条件,在那个事务插入数据之前和之后查询数据,得到的数据记录的条数不一样。

 

隔离级别

脏读

不可重复读

幻影读

序列化

N

N

N

可重复读

N

N

Y

读已提交

N

Y

Y

读未提交

Y

Y

Y

 

Oracle明确支持ANSI/ISO SQL92中定义的serializable和read committed两种事务隔离级别。

 

同时,Oracle还提供了自己独有的事务隔离级别:read only。

 

所以,可以说Oracle共支持3种事务隔离级别:

 

1.       serializable

2.       read committed

3.       read only

 

Oracle默认的隔离级别是read committed。

转载地址:http://hynsi.baihongyu.com/

你可能感兴趣的文章
c++写时拷贝1
查看>>
C++ 写时拷贝 2
查看>>
Linux网络编程---I/O复用模型之poll
查看>>
Java NIO详解
查看>>
单列模式-编写类ConfigManager读取属性文件
查看>>
java中float和double的区别
查看>>
Statement与PreparedStatement区别
查看>>
Tomcat配置数据源步骤以及使用JNDI
查看>>
before start of result set 是什么错误
查看>>
(正则表达式)表单验证
查看>>
在JS中 onclick="save();return false;"return false是
查看>>
JSTL 常用标签总结
查看>>
内容里面带标签,在HTML显示问题,JSTL
查看>>
VS编译器运行后闪退,处理方法
查看>>
用div+css做下拉菜单,当鼠标移向2级菜单时,为什么1级菜单的a:hover背景色就不管用了?
查看>>
idea 有时提示找不到类或者符号
查看>>
JS遍历的多种方式
查看>>
ng-class的几种用法
查看>>
node入门demo-Ajax让前端angularjs/jquery与后台node.js交互,技术支持:mysql+html+angularjs/jquery
查看>>
神经网络--单层感知器
查看>>