首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
数据库
> 详细
oracle事务(转)
时间:
2015-02-11 10:38:00
阅读:
182
评论:
0
收藏:
0
[点我收藏+]
标签:
今天温习oracle事务,记录如下:
事务定义
事务是保持数据的一致性,它由相关的DDL或者DML语句做为载体,这组语句执行的结果要么一起成功,要么一起失败。
我们知道SQL92标准定义了数据库事务的四个特点:
原子性 (Atomicity) :一个事务里面所有包含的SQL语句是一个执行整体,不可分割,要么都做,要么都不做
一致性 (Consistency) :事务开始时,数据库中的数据是一致的,事务结束时,数据库的数据也应该是一致的
隔离性 (Isolation): 多个事务并发的独立运行,而不能互相干扰,一个事务修改,新增,删除数据在根据当前事务的事务隔离级别基础上,其余事务能看到相应的结果(这里为什么这么说,下面我会给我具体的例子进行分析)
持久性 (Durability) : 事务被提交后,数据会被永久保存
2.
事务控制命令
COMMIT 提交事务
SAVEPOINT 事务保存点 (savepoint a)
ROLLBACK(TO) 回滚[回滚到定义的保存点] rollback to a
3.
锁的概念
锁是为了保证多个并发的事务在引用同一个资源时,对资源的保护,同时也防止事物间的相互破坏。
4.
Oracle中锁类型
共享锁(表锁)共享锁有一下几种模式
行共享模式 : 不运行其它用户插入,删除,更新操作,多个用户可以同时作用于该表,都能查询。语法如下:Lock table XX in share mode
行共享更新模式 : 允许多个用户同时锁定表中不同的行,能执行DML语句,除了那些被锁定的行。
排他锁(行锁): 不允许其它用户对该表插入,删除,修改操作,只能查询,同时其它用户不能修改和锁定表
死锁 : 所个事务对资源的相互等待,造成死锁。
5.
事务隔离级别
事务隔离级别定义了事务之间的隔离程度。SQL92标准中定义了4中隔离级别。
未提交读 (READ UNCOMMITTED) 幻想读、不可重复读和脏读都允许。
提交读 (READ COMMITTED) 允许幻想读、不可重复读,不允许脏读。
重复读 (REPEATABLE READ) 允许幻想读,不允许不可重复读和脏读。
序列化 (SERILIZABLE) 幻想读、不可重复读和脏读都不允许。
通过一些现象,可以反映出设置事务隔离级别产生的效果:
幻想读(幻读): 事务T1读取一条指定where条件的语句,返回结果集。此时事务T2插入一行新记录,恰好满足T1的where条件。然后T1使用相同的条件再次查询,结果集中可以看到T2插入的记录,这条新纪录就是幻想。
脏读: 事务T1修改了一条数据,但是还未提交,事务T2恰好读取到了这条修改后了的数据,此时T1将事务回滚,这个时候T2读取到的数据就是脏数据,称为脏读。
不可重复读取:事务T1读取一行记录,紧接着事务T2修改了T1刚刚读取的记录,然后T1再次查询,发现与第一次读取的记录不同,这称为不可重复读。
6.
Oracle的事务隔离级别
ORACLE提供了SQL92标准中的read committed和serializable,同时提供了非SQL92标准的read-only。
READ COMMITTED
这是ORACLE缺省的事务隔离级别。
事务中的每一条语句都遵从语句级的读一致性。
保证不会脏读;但可能出现非重复读和幻像。
SERIALIZABLE
简单地说,serializable就是使事务看起来象是一个接着一个地顺序地执行。
仅仅能看见在本事务开始前由其它事务提交的更改和在本事务中所做的更改(也就是说其它事务在本事务开始后所做的修改,即使提交了,本事务也看不到)
保证不会出现非重复读和幻像。
Serializable隔离级别提供了read-only事务所提供的读一致性(事务级的读一致性),同时又允许DML操作.
设置隔离级别
设置一个事务的隔离级别
SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
SET TRANSACTION READ ONLY;
设置单个会话的隔离级别
ALTER SESSION SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
ALTER SESSION SET TRANSACTION ISOLATION SERIALIZABLE;
7.具体例子
准备SQL
Sql代码
create
table A(
id
int,
name varchar2(50),
primary
key(id)
);
演示一个T1插入,T2读取数据
T1提交事务后,T2可以看到数据
我们看到了事务隔离级别的效果,那么T1,T2事务执行时,oracle怎么设置这两个事务的锁的呢?我们来看一下这个操作
当T1提交后,T2修改表A成功
演示2个事务,T1更新表A的数据,T2删除表2的数据
下面将T1提交,T2得到执行
T1提交后的情况
演示事务的隔离级别
T1事务设置隔离级别为SERIALIZABLE,T2为默认级别
有的朋友可能会问,是不是T2未提交造成的,那么我们将T2提交后的结果如下
我们看看T3的查询结果
由上述结果我们可以知道,如果事务设定了序列化的隔离级别,那么在该事务期间,其它事务对该事物中引用的资源修改将不可见。
好了,今天的总结到此,还会有后续文章
http://kingj.iteye.com/blog/1675011#bc2358875
oracle事务(转)
标签:
原文地址:http://www.cnblogs.com/softidea/p/4285290.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
数据库进阶
2021-07-29
在 Oracle 数据库中执行 SQL 语句遇到特殊字符的转义方式
2021-07-28
Windows Logstash同步 Sqlserver 到Elasticsearch
2021-07-26
mysql数据库(11):恢复数据
2021-07-26
mysql数据库(9):常用查询的例子
2021-07-26
SQLAlchemy 多对多
2021-07-26
ClickHouse的JDBC连接
2021-07-26
Apache HBase 1.7.1 发布,分布式数据库
2021-07-26
数据库常用架构和同步工作原理
2021-07-26
MySQL数据库设计规范(仅供参考)
2021-07-26
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!