使用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反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

使用mvn deploy命令上传jar包的实现

《使用mvndeploy命令上传jar包的实现》本文介绍了使用mvndeploy:deploy-file命令将本地仓库中的JAR包重新发布到Maven私服,文中通过示例代码介绍的非常详细,对大家的学... 目录一、背景二、环境三、配置nexus上传账号四、执行deploy命令上传包1. 首先需要把本地仓中要

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Spring Cloud之注册中心Nacos的使用详解

《SpringCloud之注册中心Nacos的使用详解》本文介绍SpringCloudAlibaba中的Nacos组件,对比了Nacos与Eureka的区别,展示了如何在项目中引入SpringClo... 目录Naacos服务注册/服务发现引⼊Spring Cloud Alibaba依赖引入Naco编程s依

java导出pdf文件的详细实现方法

《java导出pdf文件的详细实现方法》:本文主要介绍java导出pdf文件的详细实现方法,包括制作模板、获取中文字体文件、实现后端服务以及前端发起请求并生成下载链接,需要的朋友可以参考下... 目录使用注意点包含内容1、制作pdf模板2、获取pdf导出中文需要的文件3、实现4、前端发起请求并生成下载链接使

Java springBoot初步使用websocket的代码示例

《JavaspringBoot初步使用websocket的代码示例》:本文主要介绍JavaspringBoot初步使用websocket的相关资料,WebSocket是一种实现实时双向通信的协... 目录一、什么是websocket二、依赖坐标地址1.springBoot父级依赖2.springBoot依赖

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

Java逻辑运算符之&&、|| 与&、 |的区别及应用

《Java逻辑运算符之&&、||与&、|的区别及应用》:本文主要介绍Java逻辑运算符之&&、||与&、|的区别及应用的相关资料,分别是&&、||与&、|,并探讨了它们在不同应用场景中... 目录前言一、基本概念与运算符介绍二、短路与与非短路与:&& 与 & 的区别1. &&:短路与(AND)2. &:非短