成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用Spring解決ibatis多數據源的苦惱

開發 后端
本文描述了Spring+iBatis多數據源的配置方案。在僅使用ibatis時,每多一個數據源就需要多一份sql-map-config配置文件。采用spring的AbstractRoutingDataSource就可以簡單的解決這個問題。

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多數據源的配置方案。本文來自eddysheng的博客:《基于spring和ibatis的多數據源切換方案》。

【編輯推薦】

  1. 操作更簡單 iBatis配置文件方法
  2. 詳細:iBatis配置實例
  3. iBATIS ParameterMap配置實例淺析
  4. iBATIS的多對多映射配置淺析
  5. iBATIS中添加DAO的配置淺析
責任編輯:yangsai 來源: eddysheng的博客
相關推薦

2020-12-31 07:55:33

spring bootMybatis數據庫

2020-11-24 09:56:12

數據源讀寫分離

2022-05-18 12:04:19

Mybatis數據源Spring

2024-10-30 10:22:17

2023-09-07 08:39:39

copy屬性數據源

2023-10-31 07:52:53

多數據源管理后端

2023-10-18 15:25:29

數據源數據庫

2023-06-07 08:08:37

MybatisSpringBoot

2012-06-17 13:04:45

2020-03-13 14:05:14

SpringBoot+數據源Java

2020-06-02 07:55:31

SpringBoot多數據源

2023-01-04 09:33:31

SpringBootMybatis

2022-05-10 10:43:35

數據源動態切換Spring

2022-12-19 07:21:35

Hutool-db數據庫JDBC

2022-06-02 10:38:42

微服務數據源分布式

2017-07-21 14:50:15

數據庫DB分庫事務處理

2023-01-10 16:30:22

Spring數據庫

2017-09-04 14:52:51

Tomcat線程數據源

2014-11-20 09:47:06

Java

2025-01-17 09:11:51

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久午夜精品 | 久久新视频 | 免费国产精品久久久久久 | 国产精品久久久久久久久久不蜜臀 | 天天摸天天干 | 欧美精品欧美精品系列 | 91精品国产欧美一区二区 | 中文字幕日韩欧美 | 人人九九精 | 91精品久久久久久久久中文字幕 | 午夜影院在线免费观看视频 | 精品免费国产一区二区三区四区介绍 | 性高朝久久久久久久3小时 av一区二区三区四区 | 成人超碰 | 国产精品免费在线 | 国产精品久久久久久久久图文区 | 国产日韩精品一区二区 | 美女天天操 | 亚洲一区二区三区免费 | 日韩一区二区三区精品 | a级在线免费视频 | 亚洲精品中文字幕 | 精品成人一区二区 | 一区二区播放 | 国产中文视频 | 欧美一区二区三区 | 成人伊人 | www.天天操.com | 日韩在线观看网站 | 亚洲国产精品久久久久婷婷老年 | 精品国产精品三级精品av网址 | av片在线免费看 | 九一视频在线播放 | 国产一区二区三区四区 | 91偷拍精品一区二区三区 | 岛国精品| 久久久久免费观看 | 99视频在线免费观看 | 亚洲欧美综合精品久久成人 | 日本三级线观看 视频 | 久久亚洲欧美日韩精品专区 |