使用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

相关文章

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do