springboot

整合springboot + mybatis

2019-09-26  本文已影响0人  毛不翼

添加依赖

        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.3.0</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.0.29</version>
        </dependency>

Mybatis 配置

@Configuration
@MapperScan(basePackages = "com.example.dao.mapper",sqlSessionFactoryRef = "sqlSessionFactoryBean")
public class MybatisConfig {

    @Value("classpath:mapper/**/*.xml")
    String mapperLocations;

//    @Value("classpath:mybatis-config.xml")
//    String configLocation;

//  使用配置文件还是用配置注入,根据个人喜好决定,个人觉得用配置注入会更方便维护,更简单
    @Bean
    org.apache.ibatis.session.Configuration configuration(){
        org.apache.ibatis.session.Configuration configuration = new org.apache.ibatis.session.Configuration();
        configuration.setCacheEnabled(true);
        configuration.setLazyLoadingEnabled(true);
        configuration.setAggressiveLazyLoading(false);
        configuration.setMultipleResultSetsEnabled(true);
        configuration.setUseColumnLabel(true);
        configuration.setUseGeneratedKeys(true);
        configuration.setAutoMappingBehavior(AutoMappingBehavior.FULL);
        configuration.setDefaultExecutorType(ExecutorType.SIMPLE);
        configuration.setDefaultStatementTimeout(25000);
        return configuration;
    }

    @Bean
    PaginationInterceptor paginationInterceptor(){
        PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
        paginationInterceptor.setDialect("mysql");
        paginationInterceptor.setPageSqlId(".*Page");
        return paginationInterceptor;
    }

    @Bean
    TableShardInterceptor tableShardInterceptor(){
        return new TableShardInterceptor();
    }

    @Bean
    SqlSessionFactoryBean sqlSessionFactoryBean(DataSource masterDataSource,org.apache.ibatis.session.Configuration configuration,Interceptor[] interceptors){
        try {
            SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
            sqlSessionFactoryBean.setDataSource(masterDataSource);
            PathMatchingResourcePatternResolver resourcePatternResolver  = new PathMatchingResourcePatternResolver();
            sqlSessionFactoryBean.setMapperLocations(resourcePatternResolver.getResources(mapperLocations));
            sqlSessionFactoryBean.setConfiguration(configuration);
            sqlSessionFactoryBean.setPlugins(interceptors);
//            sqlSessionFactoryBean.setConfigLocation(resourcePatternResolver.getResource(configLocation));
            return sqlSessionFactoryBean;
        } catch (IOException e) {
            e.printStackTrace();
            throw new RuntimeException(e);
        }
    }
//    不推荐用这种方式,因为这种方式 BeanDefinitionRegistryPostProcessor的一个实现,会覆盖默认PostProcessor和产生冲突,用MapperScan注解即可。
//    @Bean
//    MapperScannerConfigurer mapperScannerConfigurer(){
//        MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
//        mapperScannerConfigurer.setBasePackage("com.jd.crm.message.instructure.mybatis.mapper");
//        mapperScannerConfigurer.setSqlSessionFactoryBeanName("sqlSessionFactoryBean");
//        return mapperScannerConfigurer;
//    }
}

关于配置属性的含义

很多人大多数开始配置的mybatis的时候,很多注解或者属性的含义不是很熟悉,主要包括springboot的机制,mybatis的配置和原理,jdbc的原理,DataSource(druid)的原理等等。这里为了避免篇幅过长,就不进行说明和讲解,大家遇到问题可以在官网查阅相关文档,或者留言和私信一起交流。

上一篇 下一篇

猜你喜欢

热点阅读