重写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
    评论
MyBatis 中,可以使用 `<databaseIdProvider>` 标签来配置不同的数据库标识,以便在 SQL 映射文件中使用不同的 SQL 语句。下面是一个配置类的示例: ```java import javax.sql.DataSource; import org.apache.ibatis.mapping.DatabaseIdProvider; import org.apache.ibatis.mapping.VendorDatabaseIdProvider; import org.mybatis.spring.SqlSessionFactoryBean; import org.springframework.context.annotation.Bean; @Configuration public class MyBatisConfig { @Bean public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource, DatabaseIdProvider databaseIdProvider) throws Exception { SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean(); sessionFactory.setDataSource(dataSource); sessionFactory.setDatabaseIdProvider(databaseIdProvider); return sessionFactory; } @Bean public DatabaseIdProvider databaseIdProvider() { VendorDatabaseIdProvider databaseIdProvider = new VendorDatabaseIdProvider(); Properties properties = new Properties(); properties.setProperty("Oracle", "oracle"); properties.setProperty("MySQL", "mysql"); properties.setProperty("PostgreSQL", "postgresql"); databaseIdProvider.setProperties(properties); return databaseIdProvider; } } ``` 在这个配置类中,我们定义了一个 `SqlSessionFactoryBean` 的 bean,其中包含了一个 `DatabaseIdProvider` 的 bean。`DatabaseIdProvider` 是用来识别数据库厂商标识的接口,`VendorDatabaseIdProvider` 是一个实现了该接口的类,可以通过设置 `Properties` 对象中的键值对来识别不同的数据库厂商。在上面的示例中,我们设置了 Oracle、MySQL 和 PostgreSQL 三种数据库的标识。这样,在 SQL 映射文件中,就可以使用 `<if>` 标签来判断当前使用的数据库类型,然后执行相应的 SQL 语句。例如: ```xml <select id="getUserList" resultType="User"> <if test="_databaseId == 'oracle'"> SELECT * FROM user WHERE ROWNUM <= #{limit} </if> <if test="_databaseId == 'mysql'"> SELECT * FROM user LIMIT #{limit} </if> <if test="_databaseId == 'postgresql'"> SELECT * FROM user LIMIT #{limit} OFFSET #{offset} </if> </select> ``` 在上面的示例中,使用了 `_databaseId` 变量来获取当前数据源的标识。这个变量的值就是我们在 `Properties` 对象中设置的键值对中的值。根据这个值,就可以执行相应的 SQL 语句。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值