Spring+Mybatis 通过databaseIdProvider支持多数据库(静态切换配置)

概述

本人最近接到一个任务,就是将原来的一个可自配置信息管理系统升级成可同时兼容oracle数据库版本(原来是仅支持mysql的)。即便大部分的sql语句通用,但是还有许多语法存在差异,所以我们可以通过mybatis自身提供的databaseIdProvider解决这个问题,这里记录一下过程。

官方描述

databaseId 如果配置了 databaseIdProvider,MyBatis 会加载所有的不带 databaseId 或匹配当前 databaseId 的语句;如果带或者不带的语句都有,则不带的会被忽略。

配置

1.配置文件目录结构
Spring+Mybatis 通过databaseIdProvider支持多数据库(静态切换配置)_第1张图片
image.png
2.config.properties
Spring+Mybatis 通过databaseIdProvider支持多数据库(静态切换配置)_第2张图片
image.png

把两个jdbc的信息整合在一起。

3.datasource.xml
 
        
        
        
        
        

        
        
        
        

        
        

        
        

        
        

        
        

        
        
        
        

        
        
        


    

    
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
    
    
        
            
                oracle
                mysql
            
        
    
    
        
    

这里两个数据源的bean对象大同小异,主要是下方增加了databseIdProvider的配置。

4.spring-mybatis.xml

    
    
    
    
    
    
        
            
        
    



    
    



    

增加sqlSessionFactory对databaseProvider的引入。

测试

至此,配置的工作已经结束,我们来进行一下本地测试。
1.DAO

public interface TestDBMapper {
    String selectTime();
}

2.mapper


 
    

此处注释掉的是第一种方法,就是一开始mybatis官方文档上说的,增加databaId就可以在运行时选择执行那一句sql。
第二种方法更为方便,可以节省很多重复性的代码。
3.JUnit测试用例

public class TestDBMapperTest extends AbstractTestBase {
    @Autowired TestDBMapper testDBMapper;
    @Test
    public void testSelectTime () {
        String time = testDBMapper.selectTime();
        System.out.println(time);
    }
}

输出结果:


Spring+Mybatis 通过databaseIdProvider支持多数据库(静态切换配置)_第3张图片
image.png

由于目前配置的是mysql数据库,所以输出sql语句用的是now()函数。

你可能感兴趣的:(Spring+Mybatis 通过databaseIdProvider支持多数据库(静态切换配置))