spring+mybatis手动切换数据源

最近在工作中遇到了一个项目要访问oracle不同用户下的表,于是仿照网上朋友们的方案实现了手动切换数据源,方法如下:

首先修改项目里的spring-config.xml,修改的地方如下,


	  
        
       
	   
	
	
	  
        
       
       
	
  
	
	
	        
	        
	            
	                
	                
	            
	        
	
 

	
		
		
		
		
		
			
				
				
			
		
	

然后添加 MultipleDataSource.java,如下:

import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;

public class MultipleDataSource extends AbstractRoutingDataSource {
    private static final ThreadLocal dataSourceKey = new InheritableThreadLocal();

    public static void setDataSourceKey(String dataSource) {
        dataSourceKey.set(dataSource);
    }
    @Override
    protected Object determineCurrentLookupKey() {
        return dataSourceKey.get();
    }
}

最后在操作数据库的类里通过 MultipleDataSource.setDataSourceKey("dataSource_fy");手动 (注意:默认数据源需要手动切换回来)

切换,如下:

 // 切换数据源为GDFY
                    MultipleDataSource.setDataSourceKey("dataSource_fy");
                    List list = czYsxxService.getUniteListByCondition(syncSearch);
                    if (list == null || list.size() == 0) {
                        logger.info("定时同步法院已交数据:数据id:"+id+",通知书号:"+payNoticeNo+"在已收信息表里不存在,开始插入已收信息");
                        int c = czYsxxService.insertSelective(ysxx);
                        // 再次切换回GDWSJF
                        MultipleDataSource.setDataSourceKey("dataSource");
                        if (c > 0) {
                            logger.info("定时同步法院已交数据:数据id:"+id+",通知书号:"+payNoticeNo+"在已收信息表里不存在,插入成功");
                            UnitePayInfo record = new UnitePayInfo();
                            record.setUnitePayInfoId(id);
                            record.setBy2("1");// 已同步
                            record.setPushTime(time);// 同步时间
                            record.setUnitRespMsg("同步成功");// 返回报文
                            plusCjgPayInfoService.updateUnitePayInfoForSchedule(record);
                            logger.info("定时同步法院已交数据:数据id:"+id+",通知书号:"+payNoticeNo+"在已收信息表里不存在,插入成功,更新支付表状态成功");
                        }
                    } else {
                        // 再次切换回GDWSJF
                        MultipleDataSource.setDataSourceKey("dataSource");
                        logger.info("定时同步法院已交数据:数据id:"+id+",通知书号:"+payNoticeNo+"已收信息表里已存在,直接更新支付表状态为已同步");
                        UnitePayInfo record = new UnitePayInfo();
                        record.setUnitePayInfoId(id);
                        record.setBy2("1");// 已同步
                        record.setPushTime(time);// 同步时间
                        record.setUnitRespMsg("同步成功");// 返回报文
                        plusCjgPayInfoService.updateUnitePayInfoForSchedule(record);
                    }

 

你可能感兴趣的:(spring+mybatis手动切换数据源)