`
谷熙亚
  • 浏览: 52167 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

事务2

    博客分类:
  • java
阅读更多

一、什么是JAVA事务 

  通常的观念认为,事务仅与数据库相关。 

  事务必须服从4个原则。原子性一致性隔离性持久性


原子性:表示事务执行过程中的任何失败都将导致事务所做的任何修改失效。
一致性:表示当事务执行失败时,所有被该事务影响的数据都应该恢复到事务执行前的状态。
隔离性:表示在事务执行过程中对数据的修改,在事务提交之前对其他事务不可见。
持久性:表示已提交的数据在事务执行失败时,数据的状态都应该正确。 

  通俗的理解,事务是一组原子操作单元,从数据库角度说,就是一组SQL指令,要么全部执行成功,若因为某个原因其中一条指令执行有错误,则撤销先前执行过的所有指令。更简答的说就是:要么全部执行成功,要么撤销不执行。 
  既然事务的概念从数据库而来,那Java事务是什么?之间有什么联系? 

  实际上,一个Java应用系统,如果要操作数据库,则通过JDBC来实现的。增加、修改、删除都是通过相应方法间接来实现的,事务的控制也相应转移到Java程序代码中。因此,数据库操作的事务习惯上就称为Java事务。 

  二、为什么需要Java事务 

  事务是为解决数据安全操作提出的,事务控制实际上就是控制数据的安全访问。举一个简单例子:比如银行转帐业务,账户A要将自己账户上的1000元转到B账户下面,A账户余额首先要减去1000元,然后B账户要增加1000 元。假如在中间网络出现了问题,A账户减去1000元已经结束,B因为网络中断而操作失败,那么整个业务失败,必须做出控制,要求A账户转帐业务撤销。这才能保证业务的正确性,完成这个操作就需要事务,将A账户资金减少和B账户资金增加方到一个事务里面,要么全部执行成功,要么操作全部撤销,这样就保持了数据的安全性。 

  三、Java事务的类型 

  Java事务的类型有三种:JDBC事务、JTA(Java Transaction API)事务、容器事务。 

  1、JDBC事务 

  JDBC 事务是用 Connection 对象控制的。JDBC Connection 接口( java.sql.Connection )提供了两种事务模式:自动提交和手工提交。 java.sql.Connection 提供了以下控制事务的方法: 

  public void setAutoCommit(boolean) 

  public boolean getAutoCommit() 

  public void commit() 

  public void rollback() 

  使用 JDBC 事务界定时,您可以将多个 SQL 语句结合到一个事务中。JDBC 事务的一个缺点是事务的范围局限于一个数据库连接。一个 JDBC 事务不能跨越多个数据库。 

  2、JTA(Java Transaction API)事务 

  JTA是一种高层的,与实现无关的,与协议无关的API,应用程序和应用服务器可以使用JTA来访问事务。 

  JTA允许应用程序执行分布式事务处理——在两个或多个网络计算机资源上访问并且更新数据,这些数据可以分布在多个数据库上。JDBC驱动程序的JTA支持极大地增强了数据访问能力。 

  如果计划用 JTA 界定事务,那么就需要有一个实现 javax.sql.XADataSource 、 javax.sql.XAConnection 和 javax.sql.XAResource 接口的 JDBC 驱动程序。一个实现了这些接口的驱动程序将可以参与 JTA 事务。一个 XADataSource 对象就是一个 XAConnection 对象的工厂。 XAConnection s 是参与 JTA 事务的 JDBC 连接。 

  您将需要用应用服务器的管理工具设置 XADataSource .从应用服务器和 JDBC 驱动程序的文档中可以了解到相关的指导。 

  J2EE应用程序用 JNDI 查询数据源。一旦应用程序找到了数据源对象,它就调用 javax.sql.DataSource.getConnection() 以获得到数据库的连接。 
 
XA 连接与非 XA 连接不同。一定要记住 XA 连接参与了 JTA 事务。这意味着 XA 连接不支持 JDBC 的自动提交功能。同时,应用程序一定不要对 XA 连接调用 java.sql.Connection.commit() 或者 java.sql.Connection.rollback() .

  相反,应用程序应该使用 UserTransaction.begin()、 UserTransaction.commit() 和 serTransaction.rollback() . 

  3、容器事务 

  容器事务主要是J2EE应用服务器提供的,容器事务大多是基于JTA完成,这是一个基于JNDI的,相当复杂的API实现。相对编码实现JTA 事务管理,我们可以通过EJB容器提供的容器事务管理机制(CMT)完成同一个功能,这项功能由J2EE应用服务器提供。这使得我们可以简单的指定将哪个方法加入事务,一旦指定,容器将负责事务管理任务。这是我们土建的解决方式,因为通过这种方式我们可以将事务代码排除在逻辑编码之外,同时将所有困难交给 J2EE容器去解决。使用EJB CMT的另外一个好处就是程序员无需关心JTA API的编码,不过,理论上我们必须使用EJB. 

  
四、三种Java事务差异 

  1、JDBC事务控制的局限性在一个数据库连接内,但是其使用简单。 

  2、JTA事务的功能强大,事务可以跨越多个数据库或多个DAO,使用也比较复杂。 

  3、容器事务,主要指的是J2EE应用服务器提供的事务管理,局限于EJB应用使用。 

  
五、总结 

  Java事务控制是构建J2EE应用不可缺少的一部分,合理选择应用何种事务对整个应用系统来说至关重要。一般说来,在单个JDBC 连接连接的情况下可以选择JDBC事务在跨多个连接或者数据库情况下,需要选择使用JTA事务如果用到了EJB,则可以考虑使用EJB容器事务。 
分享到:
评论

相关推荐

    行政事务2.docx

    行政事务2.docx

    day22--事务2

    在IT行业中,数据库操作是至关重要的,特别是在处理数据一致性与可靠性的事务管理方面。事务是数据库操作的基本单元,确保了数据的完整性和一致性。本文主要围绕事务管理展开,特别是MySQL和JDBC中的事务操作,以及...

    分布式事务实践 解决数据一致性

    2-2 事务原则与实现:SQL事务 2-3 事务原则与实现:JDBC事务(上) 2-4 事务原则与实现:JDBC事务(下) 第3章 使用Docker搭建环境 介绍了Docker的使用,通过Docker将课程环境搭建起来,方便那些不了解这些技术的...

    数据库事务与隔离级别.docx

    例如事务T1对一个表中所有的行的某个数据项做了从“1”修改为“2”的操作,这时事务T2又对这个表中插入了一行数据项,而这个数据项的数值还是为“1”并且提交给数据库。而操作事务T1的用户如果再查看刚刚修改的数据...

    mysql_innoDB 事务与锁详解

    | 步骤 | 事务1 | 事务1输出 | 事务2 | 事务2输出 | |------|----------------------------------------------|----------------|----------------------------------------------|----------------| | 1 | `...

    分布式数据库和事务处理06

    例如,事务T1先将X的值减去30,然后事务T2再将X的值乘以2,如果T1的更新未被提交,那么T2的更新就会覆盖T1的更新,T1的修改就丢失了。 不可重读是指在一个事务的不同操作之间,由于其他事务的修改,导致事务内部...

    spring事务管理1

    2. 配置事务管理器,例如DataSourceTransactionManager(基于JDBC)或HibernateTransactionManager(基于Hibernate)。 3. 启用基于注解的事务管理,并指定使用的事务管理器。 4. 使用@Transactional注解标记需要...

    数据一致的基石 透彻理解无所不在的事务 2

    数据一致的基石_透彻理解无所不在的事务_2

    19-事务-源代码.rar

    2.mysql的事务 1.QueryRunner 1.事务的特性ACID 2.并发访问问题----由隔离性引起 3.事务的隔离级别 默认是自动事务: 执行sql语句:executeUpdate() ---- 每执行一次executeUpdate方法 代表 事务自动提交 ...

    mysql事务隔离级别1

    在可重复读隔离级别下,事务2可以看到事务1开始时的数据状态,即使事务1已经提交了修改。这是因为InnoDB采用了一致性非锁定读策略,事务在读取数据时不加锁,而是读取快照数据,从而提高了并发性能。然而,这可能...

    spring 自定义事务管理器,编程式事务,声明式事务@Transactional使用

    在Spring框架中,事务管理是核心功能之一,它确保了数据操作的一致性和完整性。本教程将深入探讨如何在Spring中实现自定义事务管理器、编程式事务处理以及声明式事务`@Transactional`的使用。 首先,让我们了解事务...

    数据库事务

    在**可重复读**级别下,虽然事务1可以避免读取事务2的新记录,但如果事务2插入了一个年龄在10至30岁之间的新用户,则会发生幻读。在**提交读**级别下,事务1可能会读取到事务2已经提交的新记录,但事务1第一次读取时...

    分布式数据库和事务处理12

    每个申请需要三个事务,两个在客户端,一个在服务器端,如果队列管理器独立,事务2可能需要两阶段提交。 4. 客户恢复机制: - 如果客户超时未收到应答,可以通过队列检查申请状态。每个申请具有全局唯一的ID,便于...

    mysql数据库事务隔离级别借鉴.pdf

    在测试1中,事务2无法看到事务1未提交的修改,即使事务1已经提交,事务2仍然读取到事务开始时的数据,这是可重复读隔离级别的特性,防止了不可重复读的发生。 在测试2中,虽然事务1在事务2新增记录后没有看到新记录...

    GoldenDB事务一致性处理机制.pptx

    为了解决这些问题,GoldenDB的事务处理模块优化实践中,采用了多种技术手段,包括2PC协议、日志写入、消息数和定时器监控等,保障事务的一致性和可靠性。此外,GoldenDB还提供了丰富的监控体系和完善的运维能力,...

    ORACLE数据库事务处理和故障恢复

    "ORACLE数据库事务处理和故障恢复" ORACLE数据库事务处理和故障恢复是指在ORACLE数据库中,为了确保数据的一致性和完整性,使用事务处理和故障恢复机制来解决数据库并发操作中的问题。 一、并发控制 在多用户...

    Mongodb事务介绍与最佳实践.pptx

    如果事务1尝试修改文档,然后事务2在同一时刻尝试做同样的操作,那么第二个事务会被阻塞直到第一个事务完成。如果事务1提交,事务2可以继续;如果事务1回滚,事务2会发现冲突并回滚自己的更改。 ### 事务总结 - **...

    MySQL_InnoDB之事务与锁详解.doc

    例如,在`READ UNCOMMITTED`隔离级别下,事务1可以在未提交事务2的修改时读取数据,导致脏读。而在其他隔离级别下,事务1可能会看到事务2的不同状态,取决于隔离级别的设定。 总结来说,MySQL InnoDB的事务和锁机制...

    mysql数据库事务隔离级别[参照].pdf

    例如,在提供的测试例子中,事务1在事务2开始之前修改了记录,但在事务2中看不到这些修改,直到事务1提交。这避免了不可重复读的问题。 然而,对于幻读,MySQL的InnoDB存储引擎在可重复读隔离级别下通过使用Next-...

Global site tag (gtag.js) - Google Analytics