使用Spring解决ibatis多数据源的苦恼

2024-04-05 05:38

本文主要是介绍使用Spring解决ibatis多数据源的苦恼,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://www.linuxidc.com/Linux/2012-02/55524.htm

iBatis多数据源的苦恼

在仅使用ibatis时,多数据源简直就是梦魇,每多一个数据源就需要多一份sql-map-config配置文件。

采用spring的AbstractRoutingDataSource就可以简单的解决这个问题。

AbstractRoutingDataSource实现了javax.sql.DataSource接口,因此可以理解为一个虚拟的动态DataSource,在需要的时候根据上下文Context动态决定使用哪个数据源。

Spring+iBatis多数据源的配置

下面是一个完整的配置:

 
  1. < beans xmlns="http://www.springframework.org/schema/beans" 
  2.   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  3.   xmlns:aop="http://www.springframework.org/schema/aop" 
  4.   xmlns:tx="http://www.springframework.org/schema/tx" 
  5.   xmlns:jee="http://www.springframework.org/schema/jee" 
  6.   xsi:schemaLocation="  
  7.    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd  
  8.    http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd  
  9.    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd  
  10.    http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-2.5.xsd"> 
  11.  
  12.  
  13.  < !-- ========================= GENERAL DEFINITIONS ========================= --> 
  14.  < jee:jndi-lookup id="ds0" jndi-name="jdbc/ds0"/> 
  15.  < jee:jndi-lookup id="ds1" jndi-name="jdbc/ds1"/> 
  16.  < jee:jndi-lookup id="ds2" jndi-name="jdbc/ds2"/> 
  17.    
  18.  < bean id="dataSource" class="com.xxx.xxx.util.DynamicDataSource">    
  19.          < property name="targetDataSources">    
  20.             < map key-type="java.lang.String">    
  21.                < entry key="0" value-ref="ds0"/> 
  22.                < entry key="1" value-ref="ds1"/> 
  23.                < entry key="2" value-ref="ds2"/>    
  24.             < /map>    
  25.          < /property>    
  26.          < property name="defaultTargetDataSource" ref="1"/>    
  27.  < /bean> 
  28.         < !-- SqlMap setup for iBATIS Database Layer --> 
  29.  < bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean"> 
  30.   < property name="dataSource" ref="dataSource"/> 
  31.   < property name="configLocation" value="classpath:com/xxx/xxx/dao/sqlmap/sql-map-config.xml"/> 
  32.  < /bean> 
  33.         < bean id="testDAO" class="com.xxx.xxx.dao.impl.TestDAO"> 
  34.   < property name="sqlMapClient" ref="sqlMapClient"/> 
  35.  < /bean> 
  36.         < bean id="testService" class="com.xxx.xxx.service.impl.TestService"> 
  37.   < property name="testDAO" ref="testDAO"/> 
  38.  < /bean> 
  39. < /beans> 
  40.    

其核心是DynamicDataSource,代码如下

 
  1. package com.xxx.xxx.util;  
  2.  
  3. import org.apache.log4j.Logger;  
  4. import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;  
  5.  
  6. public class DynamicDataSource extends AbstractRoutingDataSource {  
  7.  
  8.  static Logger log = Logger.getLogger("DynamicDataSource");  
  9.  @Override 
  10.  protected Object determineCurrentLookupKey() {  
  11.   // TODO Auto-generated method stub  
  12.   return DbContextHolder.getDbType();  
  13.  }  
  14.  
  15. }  

上下文DbContextHolder为一线程安全的ThreadLocal,如下

 
  1. package com.xxx.xxx.util;  
  2.  
  3. public class DbContextHolder {  
  4.  private static final ThreadLocal contextHolder = new ThreadLocal();  
  5.  
  6.  public static void setDbType(String dbType) {  
  7.   contextHolder.set(dbType);  
  8.  }  
  9.  
  10.  public static String getDbType() {  
  11.   return (String) contextHolder.get();  
  12.  }  
  13.  
  14.  public static void clearDbType() {  
  15.   contextHolder.remove();  
  16.  }  
  17. }  
  18.    

sql-map-config.xml如下

 
  1. < ?xml version="1.0" encoding="UTF-8" standalone="no"?> 
  2. < !DOCTYPE sqlMapConfig PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"  
  3.         "http://www.ibatis.com/dtd/sql-map-config-2.dtd"> 
  4.  
  5. < sqlMapConfig> 
  6.  
  7.     < sqlMap resource="com/xxx/xxx/dao/sqlmap/Object.xml"/> 
  8.  
  9. < /sqlMapConfig> 
  10.    

这样在调用service之前只需要设置一下上下文即可调用相应的数据源,如下:

 
  1. DbContextHolder.setDbType("2");  
  2. //execute services  
  3. //.........  

dao如下

 
  1. package com.xxx.xxx.dao.impl;  
  2.  
  3. import java.util.HashMap;  
  4. import java.util.List;  
  5. import java.util.Map;  
  6.  
  7. import org.apache.log4j.Logger;  
  8. import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;  
  9.  
  10. import com.xxx.xxx.vo.TestObj;  
  11.  
  12. public class TestDAO extends SqlMapClientDaoSupport implements ITestDAO {  
  13.  
  14.     static Logger log = Logger.getLogger(TestDAO.class);  
  15.  
  16.     public TestObj getTestObj(String objID) throws Exception {  
  17.         return (TestObj) getSqlMapClientTemplate().queryForObject("getTestObj", objID);  
  18.     }  
  19. }  

 

这篇关于使用Spring解决ibatis多数据源的苦恼的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int