`
terran_li2008
  • 浏览: 200179 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

oracle事务管理相关问题总结

阅读更多

以下内容转自:http://www.blogjava.net/baixch/archive/2008/06/13/207615.html

 

 

 

1.oracle对一条sql语句的执行是怎么管理并发和恢复控制的?
一条符合语法的sql语句,定义了对数据库的操作。此操作执行的时刻,对应了数据库的一个数据状态。可以这样理解这个状态:到此执行时刻为止,没有任何数据库语句级操作正在并发执行;就是说实际上正在并发执行的多个语句级操作可以假定在此语句操作之后执行。这里强调语句级操作,是指如果一个事务包含多个操作语句,在此时刻实际已经执行了其中几个,此时刻也正在执行某一个语句,那么不能简单地认为前面几个执行的操作语句也还没发生,这是要看事务的隔离级别的,但是不管事务隔离级别是几级,语句级别上可以认为是序列执行的。
该sql语句的操作过程中认为此数据状态是保持不变的。当此操作执行结束时刻,才产生语句级数据状态影响。就是说,可能该语句同时更新了两行,但都用了同一个主键,则此时会导致违反唯一性约定而消除整个语句的影响,如果成功执行,但未必就在事务级别上影响数据状态,就是说如果所在事务回滚,此影响仍然被消除,不过正如前面所说,一个语句成功执行后,就可能影响其他语句所面对的数据状态。 
2.PL/SQL的执行是怎么管理并发和恢复控制的?
PL/SQL是在一个PL/SQL引擎中执行的。该引擎可以认为是oracle之外的单位。该引擎会解析PL/SQL,并不断发送SQL语句给ORACLE。所以和用JAVA程序通过JDBC在一个会话连接中发送多个SQL语句没有本质差别。也因此并发和恢复管理没有不同。
3.oracle死锁是怎么样产生的?
由于oracle控制并发是使用的锁机制,也因此即会产生死锁问题。oracle在执行一个语句时,会根据语句的含义,同时根据所处的事务隔离级别,解析出需要加什么样的锁,什么时候释放。而隔离级别越高,对锁资源占用越大。现在考虑这样的情形,oracle同时处理两个事务A,B。A发过来几条语句,导致ORACLE加了几把锁没有释放,B发过来几条语句,导致ORACLE加了另外几把锁没有释放,现在,A又发过来一个语句,此语句要求ORACLE加的一些锁中,有几个锁已经被B事务占用,那么A等待,而B又发过来一条语句,此语句要求ORACLE加的锁,在A手中。于是死锁出现。而隔离级别越高,死锁的可能性越大。可以分析出来,死锁的根本原因在于,事务包含的语句是分条发给oracle的,oracle不能够在事务开始时刻就解析出全部执行过程需要什么锁,什么时候释放,无法统一安排。

死锁问题归咎由谁呢?我这么理解:如果没有事务概念,oracle在语句级上控制并发,完全不会出现死锁问题。因为在解析语句时,oracle已经知道要加多少把锁,它会看目前这些锁如果能全部获得就执行,否则就等待。可是实际应用怎么能没有事务的概念呢?我同意完全可以出现新的sql语法,可以把原来的多条sql语句的含义在一个语句中定义完毕,长短不是问题,牺牲一定的语法简洁度也不是问题;然而最关键的是往往我们是在一个业务处理逻辑中,多个数据库操作之间掺杂了其他非数据库操作,而又想获取这些数据库操作作为一个整体的ACID。因此事务概念必须存在。既然如此,或许我们真得可以把一个事务可能包含的语句在事务开始时就交给oracle,尽管这样一来,有可能就包含了实际通过业务逻辑判断不会执行的语句,导致oracle浪费锁,降低并发处理能力。
我之前的文章曾经介绍过用JAVA实现同步控制,降低ORACLE隔离级别,只利用ORACLE的原子性支持。这样做的原因就在上文中基本提到了。我们在编写JAVA业务逻辑时,是知道我们需要在一串业务逻辑中操作多少次数据库的,也因此,能够在业务逻辑开始时就控制得到所有的锁再执行。这样做确实能够降低oracle压力,并消除死锁问题,然而这样做会导致同步压力集中到JAVA应用端,而且对研发人员要求也会提高。尽管如此,在JAVA应用端使用同步要灵活很多,而不必限制在表锁行锁,你甚至可以建一个森林结构的信号量数据来控制同步。
呵呵,反过来也可以理解隔离级别的问题,为什么要存在允许幻像读的隔离级别呢?隔离级别的存在是一种权衡,如果应用既不想自己控制并发,又想提高并发能力,则需要好好权衡一下吧!

分享到:
评论

相关推荐

    Java中各种事务管理技术的总结

    内容包括事务及其控制的基本概念,Oracle中的事务处理,以及JDBC,EJB,JTA事务管理内容的总结,最后还介绍了事务管理的技巧,是了解和学习JAVA事务处理不可多得的第一手资料!

    oracle使用管理笔记(一些经验的总结)

    16.oracle事务处理 34 17.oracle数据完整性 36 18.oracle 序列(sequence) 39 19.oracle 索引 40 20.oracle管理权限和角色 42 21.PL/SQL 47 (1)存储过程简单版本 47 (2)存储过程升级版本 49 (3)函数 50 (4)包 50 (5)...

    oracle数据库dba管理手册

    11.1.3 事务管理 322 11.1.4 文件定位 322 11.1.5 监控 322 11.1.6 版本考虑 323 11.1.7 DBA的角色 324 11.2 管理Oracle Financials软件包的特殊 准则 324 11.2.1 数据库结构 324 11.2.2 数据库访问 326 11.2.3 ...

    Oracle日常维护故障定位故障排除

    21 由于创建表空间时误将其创建在以‘本地管理’,导致在表空间上的所有对象无法修改其存储参数 22 错误地在系统表空间上建无关的数据文件 23 ORACLE客户端在P4上安装不成功 24由于LISTENER.ORA或TNSNAMES.ORA配置...

    Oracle11g从入门到精通2

    《Oracle11g从入门到精通》面向数据库管理人员和数据库开发人员,从实际角度出发,系统地介绍了数据库和Oracle的相关概念和原理、Oracle的数据库管理(如安装与启动,用户权限、备份与恢复等),以及Oracle的应用...

    Oracle 10g应用指导

    同其他数据库管理系统相比,Oracle产品较为庞大而复杂,因此,令许多数据库管理系统的学习者在Oracle面前止步不前,究其原因,主要是无法掌握Oracle技术的脉络。本书正是根据作者在高校和各种数据库培训班执教多年的...

    21天学通Oracle

    第19章 数据一致性与事务管理(教学视频:46分钟) 341 第20章 并发控制(教学视频:35分钟) 356 第21章 Oracle中的正则表达式(教学视频:29分钟) 369 第五篇 Oracle与编程语言综合使用实例 第22章 Oracle在...

    OracleSQL疑难解析

    《Oracle SQL疑难解析》总结了针对Oracle数据库编写SQL时经常碰到的各种问题,提供大量现成的解决方法,包括汇总和聚合数据、多表数据查询、生成和获取数据、通用查询模式、日期和时间值的处理、字符串、处理数字、...

    Oracle+10g应用指导与案例精讲

    同其他数据库管理系统相比,Oracle产品较为庞大而复杂,因此,令许多数据库管理系统的学习者在Oracle面前止步不前,究其原因,主要是无法掌握Oracle技术的脉络。本书正是根据作者在高校和各种数据库培训班执教多年的...

    ORACLE11G宝典.rar 是光盘里面的内容,书太厚咧没法影印啊

    程序设计,第5~9章分别介绍了Oracle11g的体系结构、表空间与数据文件的管理、启动和关闭数据库、网络服务与管理,第10—13章介绍了有关安全的几个内容(权限、角色、概要文件、用户的管理),第14—17章介绍了几种...

    深入解析Oracle.DBA入门进阶与诊断案例

    针对数据库的启动和关闭、控制文件与数据库初始化、参数及参数文件、数据字典、内存管理、Buffer Cache与Shared Pool原理、重做、回滚与撤销、等待事件、性能诊断与SQL优化等几大Oracle热点主题,本书从基础知识入手...

    Oracle SQL高级编程(资深Oracle专家力作,OakTable团队推荐)--随书源代码

    作者通过总结各自多年的软件开发和教学培训经验,与大家分享了掌握Oracle SQL所独有的丰富功能的技巧所在,内容涵盖SQL执行、联结、集合、分析函数、子句、事务处理等多个方面。读者可以学习到以下几个方面的技巧:...

    oracle实验报告

    例1 定义一个人事信息管理系统中存放职工基本信息的一张表。可输入如下命令: SQL>CREATE TABLE employee (empno number(6) PRIMARY KEY, /* 职工编号 name varchar2(10) NOT NULL, /* 姓名 deptno number(2) ...

    Oracle优化日记:一个金牌DBA的故事 白鳝.扫描版

    南京的死锁问题今日点评优化小技巧 Oracle的死锁优化小技巧 几个常用的与锁相关的脚本5月20日 凌晨的邮件通知短信今日点评优化小技巧 /10028事件优化小技巧 PL/SQL 优化工具profiler5月22日 ODS系统和RAC优化小技巧 ...

    北大青鸟Oracle教程集1

    Oracle 入门 Version 3.0 目标 理解与 Oracle 相关的 RDBMS结构 结构 掌握Oracle 数据类型 掌握 掌握数据定义语言 掌握数据操纵语言 掌握事务处理和数据控制命令 Oracle 简介 对象关系数据库管理系统 (ORDBMS) 提供...

    北大青鸟Oracle教程集2

    Oracle 入门 Version 3.0 目标 理解与 Oracle 相关的 RDBMS结构 结构 掌握Oracle 数据类型 掌握 掌握数据定义语言 掌握数据操纵语言 掌握事务处理和数据控制命令 Oracle 简介 对象关系数据库管理系统 (ORDBMS) 提供...

    DB2和Oracle的并发控制(锁)比较

    引言DB2多粒度封锁机制介绍Oracle多粒度锁机制介绍DB2多粒度封锁机制的监控Oracle多粒度封锁机制的监控DB2多粒度封锁机制示例总结结束语在实际的生产运行环境中,笔者在国内很多客户现场都看到开发人员和系统管理...

    oracle数据库经典题目

    10. 下列哪个子句实现对一个结果集进行分组和汇总?( D ) A.HAVING B. ORDER BY C. WHERE D. GROUP BY 11. 查询一个表的总记录数,可以采用_________统计函数。( C ) A. AVG(*) B. SUM(*) C. COUNT(*) D.MAX...

Global site tag (gtag.js) - Google Analytics