当前位置:  数据库>IP地址数字互转 iis7站长之家

Oracle 事务总结

    来源: 互联网  发布时间:2017-04-03

    本文导语: 1、事务概念:    概念:在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么完全成功执行,完成整个工作单元操作,要么一点也不执行。...

1、事务概念:  
 概念:在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么完全成功执行,完成整个工作单元操作,要么一点也不执行。  
  主要特性:确保数据库的完整性。  
2、事务的ACID特性  
  对一组SQL语句操作构成事务,数据库操作系统必须确保这些操作的原子性,一致性,隔离性,持久性.  
1、  原子性(Atomicity)  
    事务的原子性是指事务中包含的所有操作要么全做,要么不做,也就是说所有的活动在数据库中要么全部反映,要么全部不反映,以保证数据库的一致性。  
2、  一致性(Consistency)  
    事务的一致性是指数据库在事务操作前和事务处理后,其中数据必须满足业务的规则约束。  
3、  隔离性(Isolation)  
   隔离性是指数据库允许多个并发的事务同时对其中的数据进行读写或修改的能力,隔离性可以防止多个事务的并发执行时,由于它们的操作命令交叉执行而导致数据的不一致性。  
4、  持久性(durability)  
    事务的持久性是指在事务处理结束后,它对数据的修改应该是永久的。即便是系统在遇到故障的情况下也不会丢失,这是数据的重要性决定的。   
  
 
3、事务的控制语句  
   在Oracle数据库中,没有提供开始事务处理语句,所有的事务都是隐式开始的,也就是说在oracle中,用户不可以显示使用命令来开始一个事务.oracle任务第一条修改数据库的语句,或者一些要求事务处理的场合都是事务的隐式开始。但是当用户想要终止一个事务处理时,必须显示使用commit和rollback语句结束。  
  根据事务ACID属性,oracle提供了如下的事务控制语句:  
   Set transaction 设置事物属性  
   Set constrains  设置事物的约束模式  
   约束模式是指:在事务中修改数据时,数据库中的约束立即应用于数据,还是将约束推迟到当前事务结束后应用。  
   Savepoint 在事务中建立一个存储的点.当事务处理发生异常而回滚事务时,可指定事务回滚到某存储点.然后从该存储点重新执行。  
   Release  savepoint  删除存储点  
   Rollback 回滚事务 取消对数据库所作的任何操作  
   Commit 提交事务 对数据库的操作做持久的保存。  
 
 
  3、1设置事物的属性:  
  set transaction语句可用来设置事物的各种属性。该语句必须放在事务处理的第一个语句.  
也就是说,必须在任何insert、update 、delete语句以及其他的事务处理。  
  Set transaction的语句可以让用户对事务的以下属性进行设置  
    指定事务的隔离层  
    规定回滚事务所使用的存储空间  
    命名事务  
 备注:在使用set transaction语句设置属性时,对于规定回滚事务所使用的存储空间的设置很少使用.对于命名事务也非常简单,只有在分布式事务处理中才会体现出命名事务的用途.  
 
 注意:set transaction只对当前事务有效,事务终止,事务当前的设置将会失效。  
 
1、  数据异常  
事务的隔离性定义了一个事务与其它事务的隔离程度.为了更好的理解隔离层,首先讨论一下并发事务对同一个数据库进行访问可能发生的情况.在并发事务中总体来说会发生如下3种情况  
    错读 |脏读  
    非重复读取|不可重复读  
    假读|幻读  
 
    错读|脏读:当一个事务修改数据时,另一事务读取了该数据,但是第一事务由于某种原因取消对数据修改,使数据返回了原状态,这是第二个事务读取的数据与数据库中数据不一致.这就叫错读。  
 
   非重复读取:是指一个事务读取数据库中的数据后,另一个事务则更新了数据,当第一个事务再次读取其中的数据时,就会发现数据已经发生了改变,这就是非重复读取。非重复读取所导致的结果就是一个事务前后两次读取的数据不相同。  
 
   假读:如果一个事务基于某个条件读取数据后,另一个事务则更新了同一个表中的数据,这时第一个事务再次读取数据时,根据搜索的条件返回了不同的行,这就是假读。  
 
    事务中遇到的这些异常与事务的隔离性设置有关,事务的隔离性设置越多,异常就出现的越少,但并发效果就越低,事务的隔离性设置越少,异常出现的越多,并发效果越高。  
2、  选择隔离层  
   针对3中读取的数据时产生的不一致现象,在ANSI SQL标准92中定义了4个事务的隔离级别.如下图所示:  
隔离层 错读|脏读   非重复读取|不可重复读 假读|幻读  
READ UNCOMMITTED(非提交读)  是   是   是  
READ COMMITTED(提交读) 否   是   是  
Repeatable READ(可重复读)   否   否   是  
Serializable(串行读)   否   否   否  
 
Oracle支持上述四种隔离层中的两种:read committed 和serializable。除此之外oralce中还定义read only 和 read write隔离层。  
 Read committed 这是oracle默认的隔离层。  
Serializable:设置事物的隔离层位它时,事务与事务之间完全隔开,事务以串行的方式执行,这并不是说一个事务必须结束才能启动另外一个事务,而是说这些事务的执行的结果于一次执行的事务的结果一致。  
 
Read only和 read write 当使用read only时,事务中不能有任何修改数据库中数据的操作语句,这包括 insert、update、delete、create语句。Read only是serializable的一个子集,区别是read only 只读,而serialzable可以执行DML操作。Read write它是默认设置,该选项表示在事务中可以有访问语句、修改语句.但不经常使用.  
 
 
 
3、  建立set transaction的语句  
 列举如下:  
  Set transaction read only  
  Set transaction read write  
  Set transaction isolation level read committed  
  Set transaction isolation level serializable  
 
注意:这些语句是互斥的.即不能够同时设置两个或者两个以上的选项。  
 
 
4、  结束事务:  
什么情况下代表事务的结束呢?  
     
1、  Commit 提交事务  
2、  rollback 回滚事务    
 
//只读的案例  
SQL> set transaction read only;  
   
Transaction set  
   
SQL> select * from users where username='mj';  
   
USERNAME      PASSWORD      NAME             ADDRESS             ZIP  
-------------------- -------------------- -------------------- -------------------- -------  
mj                  redarmy          陈红军                                   
   
SQL> update users set password='123' where username='mj';  
   
update users set password='123' where username='mj' 
   
ORA-01456: 不能在 READ ONLY 事务处理中执行插入/删除/更新操作  
 
//脏读的案例  
SQL> set transaction isolation level read committed;  
   
Transaction set  
   
SQL> select * from users where username='mj';  
   
USERNAME      PASSWORD      NAME             ADDRESS             ZIP  
-------------------- -------------------- -------------------- -------------------- -------  
mj                  redarmy          陈红军                                   
   
SQL> update users set password='123' where username='mj';  
   
1 row updated  
   
SQL> select * from users where username='mj';  
   
USERNAME      PASSWORD      NAME             ADDRESS             ZIP  
-------------------- -------------------- -------------------- -------------------- -------  
mj                  123                 陈红军                                   
   
SQL> rollback;  
 
 
以上内容归redarmy_chen创建,如需转载请附带出处,如有疑问请发送邮件至redarmy_chen@qq.com 




























































































































    
 
 

您可能感兴趣的文章:

  • Oracle事务!使用游标提交过程
  • Oracle数据完整性嵌套事务调用分析研究
  • 在oracle下要在同一事务下插入多条记录,该怎么做??最好要有原代码
  • Oracle数据库编写有效事务指导方针
  • Oracle中死事务的检查语句
  • oracle 合并查询 事务 sql函数小知识学习
  • ORACLE数据库事务隔离级别介绍
  • MSSQL与Oracle数据库事务隔离级别与锁机制对比
  • Oracle认证:学好Oracle的六条总结
  • oracle服务启动与停止经验总结
  • Linux下Oracle常见安装错误总结及参考案例
  • Oracle中三种表连接算法的总结
  • Oracle、DB2、PostgreSQL之Sequence大总结
  • Oracle索引(B*tree与Bitmap)的学习总结
  • [Oracle] dbms_metadata.get_ddl 的使用方法总结
  • Oracle数据库中的字符处理技巧总结
  • Oracle数据字典的学习总结
  • Oracle 数据库优化实战心得总结
  • 深入ORACLE迁移到MYSQL的总结分析
  • oracle数据库sql的优化总结
  • Oracle 游标使用总结
  • oracle 日期时间函数使用总结
  • Oracle 存储过程总结(一、基本应用)
  • Oracle 存储过程总结 二、字符串处理相关函数
  • ORACLE 常用函数总结(80个)第1/2页
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3