浅谈Oracle事务【转载竹沥半夏】

所谓事务,他是一个操作序列,这些操作要么都执行,要么都不执行,是一个不可分割的工作单元。通俗解释就是事务是把很多事情当成一件事情来完成,也就是大家都在一条船上,要死一起死,要活一起活。

  为什么要引入事务?事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。通过将一组相关操作组合为一个要么全部成功要么全部失败的单元,可以简化错误恢复并使应用程序更加可靠。事务结束后,能保证数据库数据的一致性。例如银行转账,一个账号扣钱,一个账号增款,要么都执行,要么都不执行,不能只执行一条,否则会出现账款错误。这样我们就可以体会到事务的重要性了吧。其实在我们的生活中,很多事情都是要组成事务来执行的。既然它那么重要,下面我们就来深入的了解一下什么是事务吧。

一.事务的四个特征ACID

  事务的四个特征非常重要,只有满足这些特征,才能保证事务执行后只有一个结果:要么成功,要么失败。

  (1)原子性(Atomicity):组成事务处理的语句形成了一个逻辑单元,不能只执行其中的一部分。

  (2)一致性(Consistemcy):事务处理前后,数据处于一致状态,保证数据的无损。

  (3)隔离性(Isolation):对数据进行修改的多个事务是彼此隔离的,互不影响。

  (4)持久性(Durability):事务完成之后,它对于系统的影响是永久的,该修改即使出现系统故障也将一直保留,真实的修改了数据库。

  示例一

---------创建表
CREATE TABLE bank
(
customerName CHAR(10), --顾客姓名
currentMoney number(10) --当前余额
);
---------添加余额不能小于1的约束
ALTER TABLE bank ADD CONSTRAINT CK_currentMoney CHECK(currentMoney >= 1);
---------插入测试数据
INSERT INTO bank(customerName, currentMoney) VALUES('张三', 1000);
INSERT INTO bank(customerName, currentMoney) VALUES('李四', 1);
commit;
select * from bank;
---------不使用事务完成转帐操作(总金额异常)
update bank set currentMoney=currentMoney-1000 where customerName='张三';
update bank set currentMoney=currentMoney+1000 where customerName='李四';
commit;
---------清空数据,
delete bank;
select * from bank;
---------使用事务完成转账操作不会出现总金额异常
set serveroutput on;
declare
li_money number(10):=0;
begin
update bank set currentMoney=currentMoney+1000 where customerName='李四';
select currentMoney into li_money from bank where customerName='李四';
dbms_output.put_line('李四当前的余额是:'||li_money);
update bank set currentMoney=currentMoney-1000 where customerName='张三';
exception
when others then
dbms_output.put_line('撤销提交');
rollback;
end;
--转帐之后查看结果,李四的钱被回滚回去了
select * from bank;

二.回滚到保存点

  (1)rollback:回滚到最初状态,可以参考示例一。

  (2)rollback to 保留点:回滚到保留点。

  示例二

declare
num int;
begin
savepoint a; --创建保存点a
update bank set currentmoney=currentmoney-100 where customername='张三';
savepoint b; --创建保存点b
update bank set currentmoney=currentmoney+100 where customername='李四';
savepoint c; --创建保存点c
num:=# --从提示框接收一个数据,用于操作回滚到哪一点。
insert into bank values('王五',600);
savepoint d; --创建保存点d
if num=1 then
rollback to a; --当提示框中输入1时,回滚到保存点a,即全部回滚,相当于rollback;
elsif num=2 then
rollback to b; --当提示框中输入2时,回滚到保存点b
elsif num=3 then
rollback to c; --当提示框中输入3时,回滚到保存点c
else
rollback to d; --其他情况下,回滚到保存点d
end if;
end;

三.事务的隔离级别

  从上面的示例中我们可以看到事务带给我们的巨大好处,保证了数据的一致性,但是,仅仅有保证用事务执行就可以保证数据前后是一致的吗?在实际情况下,事务是并发执行的,不可避免的会出现多个事务同一时间对相同数据的操作,这样就会产生各种并发问题。

  并发问题:(1)脏读:事务T1、T2,T1读取了T2已经更改但还没有提交的数据,之后,若T2回滚,T1读到的数据就是临时无效的脏数据。

        (2)不可重复读:事务T1、T2,T1读取了一个字段,然后T2更新了该字段,当T1再次读取该字段时,值就不同了。

        (3)幻读:事务T1、T2,T1读取了一个字段,T2在在该表中又插入了一些字段,当T1再次读取时,会多出几行。

  为了解决上面这些问题,引入了隔离级别,显然,隔离级别是指一个事务与其他事务的隔离程度,隔离级别都有哪些呢,下面简单介绍了一下。

隔离级别 描述
read uncommitted(读取未提交数据) 允许事务读取未被其他事务提交的变更,脏读、不可重复读和幻读问题都会出现。
read committed(读取已提交数据) 只允许事务读取已被其他事务提交的变更,可以避免脏读,但不可重复读和幻读问题仍然存在。
repeatable committed(可重复读) 确保一个事务可以多次从一个字段中读取到相同的值,避免了脏读、不可重复读,但幻读问题仍然存在。
serializble(串行化) 在这个事务执行期间,禁止其他表对该表的插入、删除、修改操作,所有并发问题都可以避免,但性能低下。
   Oracle 支持的 2 种事务隔离级别:READ COMMITED, SERIALIZABLE。在 Oracle 默认的事务隔离级别为: READ COMMITED。Oracle同时提供了一个Read only的隔离级别。

  虽然隔离级别可以避免并发问题,但是要酌情使用,毕竟隔离级别越高,并发性就越弱,这样软件的性能就降低了。
四.总结
  (1)事务只有一个执行结果,要么成功,要么失败。
  (2)事务的四个特点:原子性、一致性、隔离性和持续性。
  (3)事务的执行过程中发生问题时,可以直接回滚到最初未执行之前的数据状态,也可以通过savepoint设置保存点,回滚到特定的保存点位置。
  (4)当多个事务同时访问相同数据时,可能产生并发问题,为了避免这些问题,引入了隔离级别。但是隔离级别越高,虽然数据一致性越好,但是并发性却更弱。所以要酌情使用。
 

浅谈Oracle事务【转载竹沥半夏】的更多相关文章

  1. 浅谈oracle事务

    所谓事务,他是一个操作序列,这些操作要么都执行,要么都不执行,是一个不可分割的工作单元.通俗解释就是事务是把很多事情当成一件事情来完成,也就是大家都在一条船上,要死一起死,要活一起活. 为什么要引入事 ...

  2. oracle中函数和存储过程的区别和联系【转载竹沥半夏】

    oracle中函数和存储过程的区别和联系[转载竹沥半夏] 在oracle中,函数和存储过程是经常使用到的,他们的语法中有很多相似的地方,但也有自己的特点.刚学完函数和存储过程,下面来和大家分享一下自己 ...

  3. 浅谈oracle树状结构层级查询之start with ....connect by prior、level及order by

    浅谈oracle树状结构层级查询 oracle树状结构查询即层次递归查询,是sql语句经常用到的,在实际开发中组织结构实现及其层次化实现功能也是经常遇到的,虽然我是一个java程序开发者,我一直觉得只 ...

  4. 浅谈oracle树状结构层级查询测试数据

    浅谈oracle树状结构层级查询 oracle树状结构查询即层次递归查询,是sql语句经常用到的,在实际开发中组织结构实现及其层次化实现功能也是经常遇到的,虽然我是一个java程序开发者,我一直觉得只 ...

  5. 浅谈分布式事务与TX-LCN

    最近做项目使用到了分布式事务,下面这篇文章将给大家介绍一下对分布式事务的一些见解,并讲解分布式事务处理框架TX-LCN的执行原理,初学入门,错误之处望各位不吝指正. 什么情况下需要使用分布式事务? 使 ...

  6. 浅谈Oracle数据库性能优化的目标

    Oracle性能优化保证了Oracle数据库的健壮性,为了保证Oracle数据库运行在最佳的性能状态下,在信息系统开发之前就应该考虑数据库的优化策略.从数据库性能优化的场景来区分,可以将性能优化分为如 ...

  7. 浅谈Oracle数据库分区表

    Oracle数据库分区是作为Oracle数据库性能优化的一种重要的手段和方法,之前,只听过分区的大名,却总未用过,最近简单学习了一下,总结如下,不对之处,还希望朋友们多多指点,交流! 1.表空间及分区 ...

  8. 浅谈Oracle权限体系

    对于数据库来讲,安全性的重要程度不言而喻,今天我们就来聊一聊Oracle的权限体系. 1.账户管理 在此之前,先解释下一个容易混淆的概念:模式.所谓模式,指的是用户账户所拥有的一组对象(比如表,索引, ...

  9. 浅谈Oracle表之间各种连接

    Oracle表之间的连接分为三种: 1.内连接(自然连接) 2.外连接 2.1.左外连接(左边的表不加限制,查询出全部满足条件的结果) 2.2.右外连接(右边的表不加限制,查询出全部满足条件的结果) ...

随机推荐

  1. 1 javascript 核心语言笔记

    //所有的双斜线之后的内容都属于注释; //变量是表示值的一个符号名字; //变量是通过var 关键字声明的; var x; //声明一个变量 //值可以通过等号赋值给变量 x = 0; //现在的变 ...

  2. bootstrap 20161012

    栅格系统 <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="u ...

  3. IOS处理点空白处不自动失去焦点的问题

    objBlurFun("input"); //如果不是当前触摸点不在input上,那么都失去焦点 function objBlurFun(sDom,time){ var time ...

  4. 通过TStringList保存csv文件,只要循环.Add表格里面的每行记录进去,保存即可

    dlgSave := TSaveDialog.Create(nil); dlgSave.filter := 'CSV文件|*.CSV'; dlgSave.DefaultExt := '*.CSV'; ...

  5. DirectShow

    1 最简单的DirectShow应用程序 — 播放视频 1.简介DirectShow是DirectX中的一套处理媒体播放.音视频采集的开发包,在DirectX SDK Summer 2004(Dire ...

  6. Connect the Cities[HDU3371]

    Connect the Cities Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...

  7. maven archetype:generate 命令简化项目模板数量

    在maven里使用 mvn archetype:generate 来创建项目是十分方便的,但有时也不尽然.在网络不好时,从网络上加载 archetype-catalog.xml文件(http://re ...

  8. requirejs:模块加载(require)及定义(define)时的路径小结

    原文地址:http://www.tuicool.com/articles/7JBnmy 接触过requirejs的童鞋可能都知道,无论是通过define来定义模块,还是通过require来加载模块,模 ...

  9. 【水】基于ege的2048

    不要问我ege怎么装 http://tieba.baidu.com/p/2227018541 好,现在我们装好了ege 开始写2048吧 没有算法,单纯模拟,不用讲解——这才叫[水]的含义 界面极度简 ...

  10. 转OSGchina中,array老大的名词解释

    转OSGchina中,array老大的名词解释 转自:http://ydwcowboy.blog.163.com/blog/static/25849015200983518395/ osg:: Cle ...