jotm oracle10g oracle 9i,施用jotm实现跨数据库事务控制

2023-11-20 19:20

本文主要是介绍jotm oracle10g oracle 9i,施用jotm实现跨数据库事务控制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java代码

1128342215.gif 

1128342216.png

1128342217.gif

packagecom.tanlan.jta.dao;

importjava.sql.Connection;

importjavax.naming.NamingException;

importjavax.sql.XAConnection;

importjavax.transaction.UserTransaction;

importorg.enhydra.jdbc.standard.StandardXADataSource;

importorg.objectweb.jotm.Jotm;

importorg.objectweb.transaction.jta.TMService;

publicclassJotmHelper {

privateTMService jotm;

privateUserTransaction userTransaction;

/**

* 启动事务管理服务

*/

publicvoidstartTMService() {

try{

jotm =newJotm(true,false);

userTransaction = jotm.getUserTransaction();

}catch(NamingException e1) {

e1.printStackTrace();

}

}

/**

* 取得数据库连接

*

* @param db

* @return

* @throws Exception

*/

publicConnection getConnection(String db)throwsException {

StandardXADataSource xads =newStandardXADataSource();

XAConnection xaconn =null;

if("mysql".equals(db)) {

xads.setDriverName("com.mysql.jdbc.Driver");

xads.setUrl("jdbc:mysql://localhost/test");

xads.setTransactionManager(jotm.getTransactionManager());

xaconn = xads.getXAConnection("root","root");

}elseif("oracle".equals(db)) {

xads.setDriverName("oracle.jdbc.driver.OracleDriver");

xads.setUrl("jdbc:oracle:thin:@localhost:1521:XE");

xads.setTransactionManager(jotm.getTransactionManager());

xaconn = xads.getXAConnection("tanlan","tanlan");

}else{

}

returnxaconn.getConnection();

}

publicvoidbegin() {

try{

userTransaction.begin();

}catch(Exception e) {

e.printStackTrace();

}

}

publicvoidcommit() {

try{

userTransaction.commit();

}catch(Exception e) {

e.printStackTrace();

}

}

publicvoidrollback() {

try{

userTransaction.rollback();

}catch(Exception e) {

e.printStackTrace();

}

}

/**

* 停止事务管理服务

*/

publicvoidstopTMService() {

jotm.stop();

jotm =null;

}

}

package com.tanlan.jta.dao;

import java.sql.Connection;

import javax.naming.NamingException;

import javax.sql.XAConnection;

import javax.transaction.UserTransaction;

import org.enhydra.jdbc.standard.StandardXADataSource;

import org.objectweb.jotm.Jotm;

import org.objectweb.transaction.jta.TMService;

public class JotmHelper {

private TMService jotm;

private UserTransaction userTransaction;

/**

* 启动事务管理服务

*/

public void startTMService() {

try {

jotm = new Jotm(true, false);

userTransaction = jotm.getUserTransaction();

} catch (NamingException e1) {

e1.printStackTrace();

}

}

/**

* 取得数据库连接

*

* @param db

* @return

* @throws Exception

*/

public Connection getConnection(String db) throws Exception {

StandardXADataSource xads = new StandardXADataSource();

XAConnection xaconn = null;

if ("mysql".equals(db)) {

xads.setDriverName("com.mysql.jdbc.Driver");

xads.setUrl("jdbc:mysql://localhost/test");

xads.setTransactionManager(jotm.getTransactionManager());

xaconn = xads.getXAConnection("root", "root");

} else if ("oracle".equals(db)) {

xads.setDriverName("oracle.jdbc.driver.OracleDriver");

xads.setUrl("jdbc:oracle:thin:@localhost:1521:XE");

xads.setTransactionManager(jotm.getTransactionManager());

xaconn = xads.getXAConnection("tanlan", "tanlan");

} else {

}

return xaconn.getConnection();

}

public void begin() {

try {

userTransaction.begin();

} catch (Exception e) {

e.printStackTrace();

}

}

public void commit() {

try {

userTransaction.commit();

} catch (Exception e) {

e.printStackTrace();

}

}

public void rollback() {

try {

userTransaction.rollback();

} catch (Exception e) {

e.printStackTrace();

}

}

/**

* 停止事务管理服务

*/

public void stopTMService() {

jotm.stop();

jotm = null;

}

}

这篇关于jotm oracle10g oracle 9i,施用jotm实现跨数据库事务控制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/396844

相关文章

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

java如何分布式锁实现和选型

《java如何分布式锁实现和选型》文章介绍了分布式锁的重要性以及在分布式系统中常见的问题和需求,它详细阐述了如何使用分布式锁来确保数据的一致性和系统的高可用性,文章还提供了基于数据库、Redis和Zo... 目录引言:分布式锁的重要性与分布式系统中的常见问题和需求分布式锁的重要性分布式系统中常见的问题和需求

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧