重写mybatis配置

1.定义配置类

@MapperScan(value = "cn.com.xxx.mapper.middle",sqlSessionTemplateRef = "middleSqlSessionTemplate")
@Configuration
public class MiddleMybatisPlusConfig implements EnvironmentAware {



    @Autowired
    private MybatisPlusConfig mybatisPlusConfig;

    private Environment environment;

    @Override
    public void setEnvironment(Environment environment) {
        this.environment = environment;
    }

    @Bean("middleSqlSessionFactory")
    public SqlSessionFactory middleSqlSessionFactory(@Qualifier("middleDataSource") DataSource middleDataSource,
                                                     @Qualifier("mybatisOraclePlusInterceptor") MybatisPlusInterceptor mybatisPgPlusInterceptor) throws Exception {
        //***导入MybatisSqlSession配置***
        MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean();
        //指明数据源
        sqlSessionFactory.setDataSource(middleDataSource);
        //指明mapper.xml位置(配置文件中指明的xml位置会失效用此方式代替,具体原因未知)
        String resourcePath = environment.getProperty("mapper.resource.path");
        sqlSessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().
                getResources(resourcePath+"/mapper/middle/**Mapper.xml"));
        //配置插件
        sqlSessionFactory.setPlugins(mybatisPgPlusInterceptor);

        //***导入Mybatis配置***
        MybatisConfiguration configuration = new MybatisConfiguration();
        configuration.setJdbcTypeForNull(JdbcType.NULL);
        configuration.setMapUnderscoreToCamelCase(true);
        configuration.setCacheEnabled(false);
        configuration.setLogImpl(StdOutImpl.class);
        mybatisPlusConfig.config(configuration);
        sqlSessionFactory.setConfiguration(configuration);

        return sqlSessionFactory.getObject();
    }



    @Bean(name = "middleSqlSessionTemplate")
    public SqlSessionTemplate middleSqlSessionTemplate(@Qualifier("middleSqlSessionFactory") SqlSessionFactory middleSqlSessionFactory) throws Exception {
        return new SqlSessionTemplate(middleSqlSessionFactory);
    }



    @Primary
    @Bean(name = "middleTransactionManager")
    public DataSourceTransactionManager middleTransactionManager(@Qualifier("middleDataSource")
                                                                         DataSource middleDataSource) {
        return new DataSourceTransactionManager(middleDataSource);
    }
}

2.定义数据源

@Slf4j
@Configuration
public class DataSourceConfig {


    /**
     * @desc  监控数据源
     * @param druidProperties
     * @return
     */
    @Bean(value = "monitorDataSource")
    public DataSource monitorDataSource(DruidDataProperties druidProperties) {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName(druidProperties.getMonitorDriverClass());
        dataSource.setUrl(druidProperties.getMonitorUrl());
        dataSource.setUsername(druidProperties.getMonitorUser());
        dataSource.setPassword(druidProperties.getMonitorPassword());
        return druidProperties.dataSource(dataSource);
    }



    


  
}

3.配置mybatisConfig配置

@EnableTransactionManagement
@Configuration
public class MybatisPlusConfig {


    @Value("${mybatis-plus.configuration.log-impl}")
    private String logImpl;

   


    @Bean("mybatisOraclePlusInterceptor")
    public MybatisPlusInterceptor mybatisOraclePlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
        paginationInnerInterceptor.setDbType(DbType.ORACLE);
        paginationInnerInterceptor.setOverflow(true);
        //添加分页插件
        interceptor.addInnerInterceptor(paginationInnerInterceptor);
        //添加乐观锁插件
        interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
        return interceptor;
    }


   



}

  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值