`
talentluke
  • 浏览: 592880 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

ORACLE的事务基础

 
阅读更多

1   事务的定义
     数据库事务是由一组 SQL 语句组成的一个逻辑工作单元。您可以把事务看作是一组不可分的 SQL 语句,这些语句作为一个整体永久记录在数据库中或一并撤销。比如在银行帐户之间转移资金:一条 UPDATE 语句将从一个帐户的资金总数中减去一部分,另一条 UPDATE 语句将把资金加到另一个帐户中。减操作和加操作必须永久记录在数据库中,或者必须一并撤销 — 否则将损失资金。这个简单的示例仅使用了两条 UPDATE 语句,但一个更实际的事务可能包含许多 INSERT、UPDATEDELETE 语句。
事务开始: 当第一个DML语句一个事务开始(数据操纵语言:insert、delete、select、update增、删、查、改)
事务结束: 当一个commitrollback语句被触发
          当一个DDL语句执行,(数据定义语言 create、alter、drop、truncate)
          当一个DCL语句执行,(数据控制语言 grant、revoke(授权、回收)、set role)
          用户退出
          机器失效或者崩溃
一个事务结束后,下一个可执行的SQL语句自动开始下一个事务,
一个DDL语句或者一个DCL语句自动提交,并且因此一个事务隐式结束.

2 控制事务
       1) commit和rollback语句的优点:
                 确保数据的一致性
                 在数据永久改变之前进行预览
                 分组逻辑相关的操作
        2) 控制事务:
                 commit 结束当前事务,使得所有未决的数据永久改变
                 savepoint name 在当前事务中标记保存点
                 rollback 结束当前事务,丢弃所有未决的数据改变
                 rollback to savepoint name 回滚当前事务到指定的保存点,从而丢弃保存点创建后的任何改变.如果忽略 to savepoint子句,rollback语句回滚整个事务.由于保存点是逻辑的,因此,没有办法列出已经创建的保存点
        3) 可以用savepoint语句在当前事务中创建一个标记
                 用rollback to savepoint 语句回退到哪个标记
                 例如:
                 update .........
                 savepoint update_done;
        
                 insert..........
                 rollback to update_done;
                 回退到保存点,可以用savepoint语句创建一个标记,它把事务分为较小的部分
                 rollback to savepoint语句丢弃未决的改变到该标记.如果你用与前面的保存点相同的
                 名字创建了另一个保存点,哪个早一点时间创建的保存点就被删除了.
                 select * from testtable t;
                 update testtable set content ='11pp1' where id = 1;
                 commit;
                 savepoint kk;
                 insert into testtable values(12,'kingking',sysdate);
                 rollback to kk;
                 commit;
         4) 隐式事务处理
                 在正常的情况下,一个自动提交发生:
                   DDL语句被发送
                   DCL语句被发送
                   正常退出,没有明确地发送commit或rollback语句
                   在正常的情况下,一个自动回滚发生:
                   系统发生异常,或者非正常退出
         5) commit或rollback之前的数据状态
                事务中所在的每一个数据改变在事务被提交之前都是临时的,在commit或rollback语句发布之前数据的状态:
                  .数据操纵操作首先影响数据库缓冲区,因此,数据以前的状态可以被恢复.
                  .当前用户可以查询表观察到数据操纵操作的结果.
                  .其他用户不能观察到当前所做的数据操纵操作的结果.oracle服务器用读一致性定每个用户看到的数据和上次提交时相同.
                  .其他用户不能改变受影响的行中的数据.
         6) 在commit之后数据的状态
                 .数据在数据库中被永久地改变.
                 .数据以前的状态永久地丢失.
                 .所有用户可以观察到事务的结果.
                 .受影响的行的锁定被释放:其他用户可以操纵那么行.
                 .所有保存点给擦除.
          7) rollback后的数据状态
                 .数据的改变被撤消.
                 .数据的以前的状态被恢复.
                 .受影响行的被释放.
          8) 语句级rollback
                 .如果一个语句的执行错误被发现,一个事务的一部分可以用隐式的回退丢弃.如果一个单个的DML语句在一个事务的执行期间失败,它的影响被一个语句级的回退撤消, 但在事务中的以前已经由DML语句完成的改变不能丢弃,它们可以由用户显示地提交或回滚.
                 .oracle在任何DDL(create,建表)语句之前和之后发布一个隐式的提交.所以即使你的DDL语句执行不成功,你也不能回退前面的语句,因此服务器已经发布提交命令.
                 .执行commit或rollback语句来明确地结束事务.
                 .oracle服务器在数据上实现以防止对数据库中数据的并发操作, 当一个DML语句成功执行时,数据库上的隐式锁被获得,默认情况下,oracle服务器在尽可能的最低级别锁定数据执行带for update子句的lock table语句或select语句可以手动获得数据库上的锁.

3 读一致性
                1)数据库用户用两种方法访问数据库:
                    读操作(select 语句)
                    写操作(插入,更新,删除语句)                
                2)你需要读一致性,所以有下面事发生:
                    数据库读者和写者被确保对数据观察的一致性.
                    读者不能观察正在变化过程中的数据.
                    写者被确保对数据库的改变以一致的方式进行.
                    一个写者所做的改变不破坏另一个写者所做的改变或与其冲突.
                3) 读一致性的目的是确保每个用户看到的数据和他最后一次提交,并且在一个DML操作操作开始之前的数据一样.
                读一致性是一种自动的执行,该操作在回退段保持一个数据库的局部的拷贝.对数据库进行一个插入,更新或者删除时,oracle服务器在数据改变之前获得相关数据的拷贝,并且将这些数据写到一个回退段(undo segment).所有读数据者,除了发布修改命令的用户,看到的数据还是改变之前的状态;他们看到数据是回退段数据快照.在改变被提交到数据库之前,只有正在修改数的用户能看见数据库的改变,除了他之外的任何人看到都是回退段的快照,这样就确保数据的读者读到一致的数据, 而不是当前正在被修改的数据.
                4) 当一个DML语句被提交的时,对数据库所做的改变对任何执行select语句的人成为可见的.在回退段的文件中被旧数据占用的空间被释放以重新使用.
         
4 锁定:
               1) 锁是防止访问相同资源的事务之间的破坏性交互机制.即可以是用户对象(如表或行),也可以是对用户不可见的系统对象(例如共享数据结构和数据字典).
               2) oracle数据库怎么锁定数据
                   oracle锁被自动执行,并且不要求用户干预.对于SQL语句隐式锁是必须的,依赖被请求的动作.隐式锁定除了select外,对所有的SQL都发生.当执行数据操纵语言(DML,insert)操作时,oracle服务器通过DML所防止数据被同时操纵.
                   用户也可以手动锁定数据,这叫显示锁定.
               3) 隐式锁定:
                2种锁的模式:
                     独占锁:不允许其他用户访问
                     共享锁:允许其他用户访问
                高级数据并发操作:
                     DML:表共享,行独占
                     查询:不需要锁
                     DDL:保护对象定义
                共享锁是在表级在DML操作期间自动获得的.用这个模式,几个事务可以在相同的资源上获得共享锁.
                对于用DML语句修改的每一行,独占锁被自动获得.独占锁在本事务被提交或回滚之前防止行被其他事物修改.该锁确保无其他用户能够在相同的时间修改相同的行,并且覆盖另一个还没有提交的改变.当你修改数据库对象时,DDL锁发生.

 

分享到:
评论

相关推荐

    oracle事务处理

    oracle事务处理,oracle基础使用,oracle

    oracle基础教程

    oracle基础教程 课程说明 1 课程介绍 1 课程目标 1 相关资料 1 第1章 ORACLE数据库概述 2 1.1 产品概述 2 1.1.1 产品简介 2 1.1.2 基本概念 3 1.2 ORACLE系统结构 4 1.2.2 ORACLE物理结构 4 1.2.3 系统全局区 6 ...

    《Oracle 12c数据库基础教程》教学课件—12办公事务管理系统(Visual C#).pdf

    《Oracle 12c数据库基础教程》教学课件—12办公事务管理系统(Visual C#).pdf《Oracle 12c数据库基础教程》教学课件—12办公事务管理系统(Visual C#).pdf《Oracle 12c数据库基础教程》教学课件—12办公事务管理系统...

    Oracle事务概念及基础知识.pdf

    在测试通过的基础上,采用讲解结合实例的方式,对Oracle 事务概念和知识进行了说明和讲解,并对关键知识点进行了标注,读者只需按照本文内容逐步进行学习和操作,即可完成Oracle事务的学习和掌握。

    Oracle Sql基础.doc

    Oracle Sql基础很系统的介绍了oracle,从基本是SQL语句到转换函数,多表查询,操纵数据,事务处理,对表的操作等做了详细讲解,希望能给朋友们带来点帮助。

    oracle基础培训

    Oracle比较全面的培训教程,而且还是PPT的...ch15事务处理和并发控制.ppt ch16闪回操作.ppt ch17数据传输技术.ppt ch18使用大对象技术.ppt chap19Oracle的数据字典.ppt 应该可以帮助你快速而又全面的熟悉Oracle数据库。

    Oracle数据库基础教程-参考答案

    Oracle之所以得到广大用户的青睐,其主要原因在于:支持多用户、大事务量的事务处理、提供标准操作接口、实施安全性控制和完整性控制、支持分布式数据处理、具有可移值性、可兼容性和可连接性。 (7)

    ORACLE基础培训文档

    oracle 基础培训doc文档:ORACLE公司自86年推出版本5开始,系统具有分布数据库处理功能.88年推出版本6,ORACLE RDBMS(V6.0)可带事务处理选项(TPO),提高了事务处理的速度.1992年推出了版本7,在ORACLE RDBMS中可带过程...

    Oracle从基础到熟练(太实用了)

    oracle基础: ①:如何进入Oracle ②:常见的开发工具 ③:创建/DB/TB/用户 授权等操作 二. oracle体系结构组件 ①:oracle完整的体系结构 ②:oracle实例的组成 ③:oracle数据库的组成 三.SQL函数与SQL查询 ①:Oracle...

    数据库开发 Oracle数据库 SQL开发教程 第01章 Oracle数据库基础(共60页).pdf

    数据库开发 Oracle数据库 SQL开发教程 第01章 Oracle数据库基础(共60页).pdf 数据库开发 Oracle数据库 SQL开发教程 第02章 编写简单的查询语句(共34页).pdf 数据库开发 Oracle数据库 SQL开发教程 第03章 限制...

    Oracle 数据库从零基础入门到精通培训视频教程(TB销售).zip

    Oracle 数据库从零基础入门到精通培训视频教程(TB销售)【第01阶段】Oracle 数据库零基础入门【第02阶段】Oracle 常用CURD讲解【第03阶段】Oracle 事务、视图、序列【第04阶段】Oracle 存储过程、游标、函数【第05...

    Oracle 基础知识 -大全- 原创整理.pdf

    1.掌握oracle表的管理(创建/维护) 2.掌握对oracle表的各种查询技巧 3.学会创建新的oracle数据库 4.掌握oracle表对数据操作技巧 5.掌握在java程序中操作oracle 6.理解oracle事物概念 7.掌握oracle各种sql函数 8....

    Oracle PL SQL基础

    PL/SQL(Procedure Language/Structuer Query Language)是Oracle对标准SQL规范的扩展,全面支持SQL的数据操作、事务控制等。PL/SQL完全支持SQL数据类型,减少了在应用程序和数据库之间转换数据的操作。

    oracle数据库基础教程

    第二十二章 事务( 数 据库系 统 概论 ) ............................... . ............................... . ....................... 99 第二十三章 用户管 理 ............................... . ..............

    Oracle 教案(教程)

    第1章 Oracle基础知识 1.1 Oracle简介 1.2 Oracle 的版本 1.3 Oracle的安装(演示) ...第4节 Oracle事务处理 第5节 SQL优化 第6节 PL( Procedural Language) / SQL编程基础 …… …… …… …… 第14节 TNS基本配置

    jfsky.com-Oracle数据库基础知识

    2.1.2 事务管理 23 2.1.3 数据库管理员(DBA) 24 2.1.4 ORACLE的四种状态 25 2.2 SQL*Plus方式的ORACLE数据库启动和关闭 26 2.2.1 启动数据库 26 2.2.2 关闭数据库 26 2.3 svrmgrl方式的ORACLE数据库启动和关闭 28 ...

    Oracle精髓(第4版)

    最新的Oracle数据库11g特性:查询结果集缓存、自动内存管理、实时应用程序测试、高级压缩、全面回忆、活跃数据守卫选项以及对OLAP选项的变更(作为物化视图进行透明访问和管理)、Flashback事务命令、透明数据加密、...

    完整版Oracle11数据库教程课件 全套PPT课件资源集合 全套12个章节.rar

    完整版Oracle11数据库教程课件 第4章_修改数据及事务(共16页).ppt 完整版Oracle11数据库教程课件 第5章_表空间(共37页).ppt 完整版Oracle11数据库教程课件 第6章_创建表及约束(共39页).ppt 完整版Oracle11...

Global site tag (gtag.js) - Google Analytics