自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用Spring解決ibatis多數(shù)據(jù)源的苦惱

開(kāi)發(fā) 后端
本文描述了Spring+iBatis多數(shù)據(jù)源的配置方案。在僅使用ibatis時(shí),每多一個(gè)數(shù)據(jù)源就需要多一份sql-map-config配置文件。采用spring的AbstractRoutingDataSource就可以簡(jiǎn)單的解決這個(gè)問(wèn)題。

iBatis多數(shù)據(jù)源的苦惱

在僅使用ibatis時(shí),多數(shù)據(jù)源簡(jiǎn)直就是夢(mèng)魘,每多一個(gè)數(shù)據(jù)源就需要多一份sql-map-config配置文件。

采用spring的AbstractRoutingDataSource就可以簡(jiǎn)單的解決這個(gè)問(wèn)題。

AbstractRoutingDataSource實(shí)現(xiàn)了javax.sql.DataSource接口,因此可以理解為一個(gè)虛擬的動(dòng)態(tài)DataSource,在需要的時(shí)候根據(jù)上下文Context動(dòng)態(tài)決定使用哪個(gè)數(shù)據(jù)源。

Spring+iBatis多數(shù)據(jù)源的配置

下面是一個(gè)完整的配置:

  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.    

這樣在調(diào)用service之前只需要設(shè)置一下上下文即可調(diào)用相應(yīng)的數(shù)據(jù)源,如下:

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

【編輯推薦】

  1. 操作更簡(jiǎn)單 iBatis配置文件方法
  2. 詳細(xì):iBatis配置實(shí)例
  3. iBATIS ParameterMap配置實(shí)例淺析
  4. iBATIS的多對(duì)多映射配置淺析
  5. iBATIS中添加DAO的配置淺析
責(zé)任編輯:yangsai 來(lái)源: eddysheng的博客
相關(guān)推薦

2020-12-31 07:55:33

spring bootMybatis數(shù)據(jù)庫(kù)

2020-11-24 09:56:12

數(shù)據(jù)源讀寫分離

2022-05-18 12:04:19

Mybatis數(shù)據(jù)源Spring

2024-10-30 10:22:17

2023-09-07 08:39:39

copy屬性數(shù)據(jù)源

2023-10-31 07:52:53

多數(shù)據(jù)源管理后端

2023-10-18 15:25:29

數(shù)據(jù)源數(shù)據(jù)庫(kù)

2023-06-07 08:08:37

MybatisSpringBoot

2012-06-17 13:04:45

2020-03-13 14:05:14

SpringBoot+數(shù)據(jù)源Java

2020-06-02 07:55:31

SpringBoot多數(shù)據(jù)源

2023-01-04 09:33:31

SpringBootMybatis

2022-05-10 10:43:35

數(shù)據(jù)源動(dòng)態(tài)切換Spring

2022-12-19 07:21:35

Hutool-db數(shù)據(jù)庫(kù)JDBC

2022-06-02 10:38:42

微服務(wù)數(shù)據(jù)源分布式

2023-01-10 16:30:22

Spring數(shù)據(jù)庫(kù)

2017-07-21 14:50:15

數(shù)據(jù)庫(kù)DB分庫(kù)事務(wù)處理

2017-09-04 14:52:51

Tomcat線程數(shù)據(jù)源

2025-01-17 09:11:51

2014-11-20 09:47:06

Java
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)