oracle事务(转)

时间:2021-10-10 08:45:12

今天温习oracle事务,记录如下:

  1. 事务定义
           事务是保持数据的一致性,它由相关的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
      1. create table A(
      2. id int,
      3. name varchar2(50),
      4. primary key(id)
      5. );
    • 演示一个T1插入,T2读取数据
    • oracle事务(转)
    • T1提交事务后,T2可以看到数据
    • oracle事务(转)
    • 我们看到了事务隔离级别的效果,那么T1,T2事务执行时,oracle怎么设置这两个事务的锁的呢?我们来看一下这个操作
    • oracle事务(转)
    • 当T1提交后,T2修改表A成功
    • oracle事务(转)
  • 演示2个事务,T1更新表A的数据,T2删除表2的数据
    • oracle事务(转)
    • 下面将T1提交,T2得到执行
    • oracle事务(转)
    • T1提交后的情况
    • oracle事务(转)
  • 演示事务的隔离级别
    • T1事务设置隔离级别为SERIALIZABLE,T2为默认级别
    • oracle事务(转)
    • 有的朋友可能会问,是不是T2未提交造成的,那么我们将T2提交后的结果如下
    • oracle事务(转)
    • 我们看看T3的查询结果
    • oracle事务(转)
    • 由上述结果我们可以知道,如果事务设定了序列化的隔离级别,那么在该事务期间,其它事务对该事物中引用的资源修改将不可见。

      好了,今天的总结到此,还会有后续文章

http://kingj.iteye.com/blog/1675011#bc2358875
 
 
 

oracle事务(转)的更多相关文章

  1. Oracle事务

    Oracle事务的ACID特性 原子性Atomicity:事务中的所有动作要么都发生,要么都不发生. 一致性Consistency:事务将数据库从一种状态转变为下一种一致状态. 隔离性Isolatio ...

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

    浅谈Oracle事务[转载竹沥半夏] 所谓事务,他是一个操作序列,这些操作要么都执行,要么都不执行,是一个不可分割的工作单元.通俗解释就是事务是把很多事情当成一件事情来完成,也就是大家都在一条船上,要 ...

  3. Oracle事务之一:锁和隔离

    Oracle事务之一:锁和隔离 一. 事务概述 事务管理是数据库处理的核心.数据库既要保证用户能并发地执行事务,还要保证数据库的一致性. 当第一条可执行的SQL开始执行,就隐形地开始了一个事务,直到遇 ...

  4. oracle事务和锁

    数据库事务概括 1. 说明 一组SQL,一个逻辑工作单位,执行时整体修改或者整体回退. 2.事务相关概念 1)事务的提交和回滚:COMMIT/ROLLBACK 2)事务的开始和结束 开始事务:连接到数 ...

  5. oracle事务和锁(转)

    If you use a SET TRANSACTION statement, then it must be the first statement in your transaction. How ...

  6. oracle 事务 与 提交

    Oracle事务 一般事务(DML)即数据修改(增.删.改)的事务事务会将所有在事务中被修改的数据行加上锁(行级锁),来阻止其它人(会话)同时对这些数据的修改操作.当事务被提交或回滚后,这些数据才会被 ...

  7. Oracle事务隔离级别处理差异

    Oracle事务隔离是事务读操作不同程度的数据隔离,分为READ_UNCOMMITTED.READ_COMMITTED(默认).SERIALIZABLE. Oracle事务隔离级别SERIALIZAB ...

  8. Oracle事务与锁

    Oracle事务与锁 2017-12-13 目录 1 数据库事务概括  1.1 事务定义  1.2 事务生命周期  1.3 事物的特性  1.4 死锁2 事务相关语句  2.1 事务相关语句概括  2 ...

  9. 转:oracle 事务

    原文地址:http://blog.csdn.net/junmail/article/details/5556561 关于Oracle事务的总结 1.什么是事务,事务的特性是什么? 事务的任务便是使数据 ...

随机推荐

  1. 在.NET下多层架构企业管理系统的开发

    引言 .NET 框架是微软开发出的新一代开发平台.允许应用程序通过 Internet 进行通讯和共享数据,而不管所采用的是哪种操作系统.设备或编程语言.本文介绍的管理系统是在.NET平台下开发的,以极 ...

  2. Lucene系列-索引文件

    本文介绍下lucene生成的索引有哪些文件组成,每个文件包含了什么信息.基于Lucene 4.10.0. 数据结构 索引(index)包含了存储的文档(document)正排.倒排信息,用于文本搜索. ...

  3. qt-5.6.0 移植之实现板子与ubuntu主机通过网络进行文件传输

    经过一上午的调试以及同事的帮助,终于实现板子与主机的文件传输. 第一步关闭所有的防火墙 在 Windows 里面是在控制面板->安全->Windows 防火墙->自定义设置 在ubu ...

  4. http://blog.csdn.net/luxiaoyu_sdc/article/details/7333024

    http://blog.csdn.net/luxiaoyu_sdc/article/details/7333024 http://blog.csdn.net/kkdelta/article/detai ...

  5. Content-Disposition的使用和注意事项

    转载:http://www.cnblogs.com/jzaileen/articles/1281025.html 最近不少Web技术圈内的朋友在讨论协议方面的事情,有的说web开发者应该熟悉web相关 ...

  6. poj3620

    #include<iostream>#include<string>#include<stack>#include<vector>#include&lt ...

  7. IT人大学生活之&OpenCurlyDoubleQuote;做点正经事”

    最近一直主抓部门的人事招聘工作:很多到手的简历,特别是毕业一年之内的同学的简历上面都会写到:在xxx餐饮公司实习,获得了与人交流的经验:在学生会组织了哪些文体活动:在大四参加了一些与软件开发不相关的一 ...

  8. 省市区三级联动插件:app-jquery-cityselect&period;js

    (function ($) { $.fn.cityselect = function (options) { var settings = $.extend ({}, options); this.e ...

  9. Redis基本数据结构总结之SET、ZSET和HASH

    Redis基本数据结构总结 前言 Redis的特点在于其读写速度特别快,因为是存储在内存中的,其非常适合于处理大数据量的情况:还有一个是其不同于其他的关系型数据库,Redis是非关系型数据库,也就是我 ...

  10. HTML5新特性&colon;元素的classList属性与应用

    在html5新增的classList之前, 操作元素的class用的是className这个属性,而如果要向jquery封装的hasClass, removeClass, addClass, togg ...