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

JTA (XA)事务和JDBC事务

    博客分类:
  • java
阅读更多

今天看到一个贴,说是否该在service中操作事务.个人认为事务尽量在service层操作,在dao层尽量不要写业务逻辑.

 

回头看看事务,以前写的代码真的乱七八糟.对事务的认识太局限了.很多业务逻辑都写在dao的事务里面,耦合在一起,完全就

 

浪费了我分service和dao层的用意.原来的代码只是形式上区分,实际上还是耦合了好多..看来要好好研究一下事务在

 

service的处理办法.尽量完美的解决.

 

以下是网络上转载来的一些事务的简单介绍,没有分层思想在里面.

 

事务简介
  一般情况下,J2EE应用服务器支持JDBC事务、JTA(Java Transaction API)事务(一般由容器来进行管理)。通常,最好不要在程序中同时使用上述三种事务类型,比如在JTA事务中嵌套JDBC事务。第二方面,事务要在尽可能短的时间内完成,不要在不同方法中实现事务的使用(事务的嵌套要求更加良好的设计)。

JDBC事务
  在JDBC中怎样将多个SQL语句组合成一个事务呢?在JDBC中,打开一个连接对象Connection时,缺省是auto-commit模式,每个SQL语句都被当作一个事务,即每次执行一个语句,都会自动的得到事务确认。为了能将多个SQL语句组合成一个事务,要将auto-commit模式屏蔽掉。在auto-commit模式屏蔽掉之后,如果不调用commit()方法,SQL语句不会得到事务确认。在最近一次commit()方法调用之后的所有SQL会在方法commit()调用时得到确认。例如下面的代码:

/**
* 测试Jboss中的JDBC事务
* 
*/
jjava.sql.Connection conn = null;
try{
javax.sql.DataSource ds = (javax.sql.DataSource) context.lookup("java:/OracleDS");
conn = ds.getConnection();
conn.setAutoCommit(false);
java.sql.Statement statement = conn.createStatement();
/**
*
* 数据库操作
*
*/
conn.commit();
} catch (Exception e) {
if(conn!=null)
try{conn.rollback();}catch(Exception e1){out.println("catch:事务回滚失败!
");}
out.println("catch:" + e.getClass() + ";" + e.getMessage()+"
");
}finally{
if(conn!=null) 
try{conn.close();}catch(Exception e1){out.println("finally:关闭数据库连接失败!
");}
}

 
毕竟JDBC事务大多数程序员可能经常使用,而且比较相对简单,就不作过多的描述了

JTA (XA)事务
  Java 事务 API(JTA) 及其同门兄弟 Java 事务服务(Java Transaction Service JTS)为 J2EE 平台提供了分布式事务服务。一个分布式的事务涉及一个事务管理器和一个或者多个资源管理器。一个资源管理器是任何类型的持久性的数据存储。事务管理器负责协调所有事务参与者之间的通信。
  与本地事务相比,XA 协议的系统开销相当大,因而应当慎重考虑是否确实需要分布式事务。只有支持 XA 协议的资源才能参与分布式事务。如果事务须登记一个以上的资源,则需要实现和配置所涉及的资源(适配器、JMS 或 JDBC 连接池)以支持 XA。

 

JTA事务工作流程
  WEB服务器(比如:WebLogic Server)将根据以下条件返回不同种类的包装器:

    1、所使用的 JDBC 驱动程序类是否支持 XA
    2、是从 DataSource 还是从 TxDataSource 获得连接
    3、调用 getConnection() 时是否在事务内运行
    4、是否通过 RMI 从远程获得连接

  决定返回哪种包装器的算法的工作方式如下:

import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
import javax.transaction.SystemException;
import javax.transaction.UserTransaction;

import java.sql.Statement;
import java.sql.Connection;

/**
 * @author Administrator
 *
 */
public class JTAtest {

 /**
  * @param args
  */
 public static InitialContext getContext(){
  InitialContext ic = null;
  try {
   ic = new InitialContext();
  } catch (NamingException e) {
   e.printStackTrace();
  }
  return ic;
  
 }
 
 public static UserTransaction getUserTransaction(){
  UserTransaction ut = null;
  try {
   ut = (UserTransaction) getContext().lookup("UserTransaction");
  } catch (NamingException e) {
   e.printStackTrace();
  }
  return ut;
  
 }
 
 public static void main(String[] args) {
  InitialContext ic = null;
  UserTransaction ut = null;
  DataSource ds = null;
  
  try { 
   ic = getContext();
   ut = getUserTransaction();
   ds = (DataSource) ic.lookup("MySqlDS");

   ut.begin();
  
   Connection c = ds.getConnection();
   Statement s = c.createStatement();
   s.execute("insert into student values (2, 'hehe')");
   
   ut.commit();
   System.out.println("事务处理成功");
   
  } catch (Exception e) {
   try {
    ut.rollback();
   } catch (IllegalStateException e1) {
    e1.printStackTrace();
   } catch (SecurityException e1) {
    e1.printStackTrace();
   } catch (SystemException e1) {
    e1.printStackTrace();
   }
   e.printStackTrace();
  } 

 }

}

 

分享到:
评论
3 楼 linpyi 2009-08-21  
Wuaner 写道
你都说了,“事务尽量在service层操作,在dao层尽量不要写业务逻辑”

那我想问问,你的那个jdbc事务的例子,你觉得算是dao层还是service层的那?

很明显是dao层,但是你的事务处理正是在这里做的。



“事务尽量在service层操作,在dao层尽量不要写业务逻辑”
这句话你写了跟没写一样。


我这篇主要是转载介绍事务的一些基本用法,最上面2句话是我的一些见解,2个可能不能放在一起引起误会.谢谢指出.
2 楼 Wuaner 2009-08-17  
你都说了,“事务尽量在service层操作,在dao层尽量不要写业务逻辑”

那我想问问,你的那个jdbc事务的例子,你觉得算是dao层还是service层的那?

很明显是dao层,但是你的事务处理正是在这里做的。



“事务尽量在service层操作,在dao层尽量不要写业务逻辑”
这句话你写了跟没写一样。
1 楼 linpyi 2009-01-09  
以上的事务实例是网上找来的,到处都一样,具体出处已经不详了.看代码比较容易理解.

相关推荐

    JDBC事务和JTA(XA)事务

    JDBC事务和JTA(XA)事务 JDBC事务和JTA(XA)事务是两种常见的数据库事务类型,它们都可以用来管理数据库事务,确保数据库的一致性和可靠性。 JDBC事务 JDBC事务是Java Database Connectivity(JDBC)的事务机制,它...

    JDBC-JTA.rar_jdbc_jta_jta JDBC

    **JDBC(Java Database Connectivity)**是Java编程语言中...学习并实践这些示例,可以帮助开发者深入理解JDBC和JTA的使用,如何在Java应用中进行数据库访问和事务管理,这对于开发企业级的、高可用性的系统至关重要。

    Java中JDBC事务与JTA分布式事务总结与区别

    本文将重点探讨JDBC事务和JTA分布式事务的区别和应用场景。 首先,JDBC事务是基于数据库连接(Connection)进行管理的。在Java程序中,我们可以通过Connection对象的setAutoCommit、commit和rollback方法来控制事务...

    springboot整合JTA组件,多数据源事务管理

    JTA事务比JDBC事务更强大。一个JTA事务可以有多个参与者,而一个JDBC事务则被限定在一个单一的数据库连接。下列任一个Java平台的组件都可以参与到一个JTA事务中 2、分布式事务 分布式事务(DistributedTransaction...

    spring + JTA + JOTM实现分布式事务

    本教程将深入探讨如何使用Spring框架、Java Transaction API (JTA) 和 Java Open Transaction Manager (JOTM) 来实现这样的分布式事务管理。 首先,我们来了解一下JTA。JTA是Java平台的标准事务API,它允许应用程序...

    JTA 分布式事务 XAPool 1.5和1.6的所有jar包,源码包

    2. **事务支持**:作为JTA的一部分,XAPool能够参与全局事务,确保数据的一致性和完整性。 3. **故障恢复**:当数据库连接出现问题时,XAPool可以检测到并自动进行故障切换,确保系统的高可用性。 4. **监控和统计**...

    使用JTA实现跨库事务

    本文将深入探讨如何使用JTA来实现跨库事务,确保数据的一致性和完整性。 首先,我们需要理解JTA的核心概念。JTA提供了一个统一的API,使得应用程序可以透明地处理分布式事务,而无需关心底层的事务管理细节。它定义...

    java事务管理和事务分类

    在实际应用中,选择合适的事务类型取决于应用的需求,例如,简单的单数据库应用可能只需要JDBC事务,而复杂的分布式系统可能需要利用JTA进行事务管理。理解这些概念和机制对于构建健壮的、能够处理复杂业务逻辑的...

    jta.jar包;jta.jar包

    6. **JTA与JDBC/Java Persistence API (JPA)**: 在JDBC连接上启用JTA事务,需要使用`javax.sql.DataSource.getConnection(UserTransaction, ConnectionProperties)`方法,或者在JPA中通过`@Transactional`注解声明...

    Jta的jar包

    **标题与描述解析** ...总结,JTA和JBarcode分别代表了Java环境中处理分布式事务和生成条形码的两个重要工具。在开发企业级Java应用,特别是涉及数据库操作和跨系统数据交换时,理解和使用这些技术是非常关键的。

    java实现JTA简单例子

    5. **XADataSource**:这是JDBC驱动的一种扩展,它实现了`XAResource`接口,允许数据库连接参与到JTA事务中。在描述中提到了`mysql-connector-java`,这意味着我们将使用MySQL数据库,并且其JDBC驱动支持JTA。 在...

    基于JTA的跨数据库分布式事务的实现.pdf

    JTA定义了一套接口和规范,包括UserTransaction、TransactionManager和XAResource等,来协调和控制事务的生命周期。 **2. 事务处理** 事务是保证业务操作完整性的基本单元,遵循ACID原则: - **原子性(Atomicity)...

    Spring+iBatis+JOTM实现JTA事务

    本文将详细介绍如何使用Spring框架、iBatis(现称为MyBatis)和JOTM来实现Java Transaction API (JTA)的分布式事务处理。 #### 二、基础知识简介 **1. Spring框架** - **概述**:Spring是一个开源的轻量级Java...

    Java事务处理总结[归类].pdf

    Java事务主要分为三种类型:JDBC事务、JTA(Java Transaction API)事务和容器事务。 1. JDBC事务是基于数据库连接(Connection对象)进行控制的。默认情况下,JDBC连接处于自动提交模式,每个SQL语句都默认作为一...

    Java事务处理总结

    根据应用场景的不同,可以选择使用JDBC事务、JTA事务或容器事务等不同的事务处理方式。每种方式都有其特定的应用场景和优势,开发者应根据具体需求选择最合适的事务处理机制。通过合理利用这些事务管理技术,可以...

    jta-1.0.1B.jar

    在较小规模的应用或者对事务要求不高的场景下,可能更适合使用轻量级的事务管理机制,如JDBC的Connection的commit()和rollback()方法。 总之,JTA-1.0.1B.jar作为Java事务处理的关键组件,提供了强大的事务管理能力...

    XA与非XA驱动差异

    - **非XA驱动**:通常指的是普通的JDBC驱动,它支持基本的SQL操作和单个数据源的事务管理。这种类型的驱动适用于简单的应用程序,这些应用程序通常只涉及到一个数据库,并且不需要复杂的分布式事务处理。 - **XA...

    JTA 深度历险 - 原理与实现.pdf

    事务处理分为本地事务和分布式事务两种方式。本地事务适用于操作单一数据源的应用,它依赖于底层资源管理器,如数据库连接。本地事务的优点是部署灵活,但它不支持跨多个数据源的分布式事务处理。本地事务处理时,...

    jta-1_0_1B-classes.jar

    集成JTA到项目中,开发者需要配置事务管理器,例如使用JBoss Transaction Manager或WebLogic的Transaction Service,并确保所有的持久化层(如JPA、JDBC)都支持XAResource。同时,业务逻辑层需要适当地调用...

    事务处理与异常处理全面的讲解

    1. **JDBC事务**:通过`java.sql.Connection`对象进行控制。默认情况下,JDBC连接处于自动提交模式,可通过`setAutoCommit(false)`关闭自动提交,然后手动调用`commit()`或`rollback()`来开始和结束事务。例如,一个...

Global site tag (gtag.js) - Google Analytics