SpringBoot整合mybatis的mybatis-spring的配置方式

摘要: 传统的配置方式整合SpringBoot与mybatis

        我大概是15年初的时候,接触了SpringBoot,不过只开发了一个小项目,就没再使用过。时隔两年,SpringBoot变的热火朝天,我也不得不认真学习一下了,以下个人心得,愿对新手有所帮助。

SpringBoot集成MyBatis有两种方式,一种简单的方式就是使用MyBatis官方提供的:

mybatis-spring-boot-starter

另外一种方式也是我推荐的整合方式:                                                                                                     就是仍然用类似mybatis-spring的配置方式,这种方式需要自己写一些代码,但是可以很方便的控制MyBatis的各项配置。

①:在http://start.spring.io/,配置你的项目信息并下载,我的是《1.5.9.RELEASE》最初的应该如下图:

SpringBoot整合mybatis的mybatis-spring的配置方式_第1张图片

②:在POM文件中加,整合的最基础的包,包版本你们自己定

org.springframework.bootspring-boot-starter-weborg.springframework.bootspring-boot-starter-jdbcorg.mybatismybatis${mybatis.version}org.mybatismybatis-spring${mybatis-spring.version}org.mybatis.cachesmybatis-ehcache${mybatis-ehcache.version}mysqlmysql-connector-javacom.alibabadruid${druid.version}

我的包版本:

UTF-8UTF-81.83.4.51.3.11.1.05.1.451.1.6

配置application.properties,很多人用的application.yml,但是我认为application.yml文件快速检索很麻烦,东西多了找一个元素很蛋疼,也许我还没领悟到yml的优势。所以我也还是用以前的.properties的配置文件,如下:

spring.datasource.driverClassName = com.mysql.jdbc.Driverspring.datasource.url =jdbc:mysql://192.168.1.206:3306/community?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&failOverReadOnly=falsespring.datasource.username = rootspring.datasource.password =1234

重点来了,整合Mybatis,配置dataSoure,和sqlSessionFactory:

importjavax.sql.DataSource;importorg.apache.ibatis.session.SqlSessionFactory;importorg.mybatis.spring.SqlSessionFactoryBean;importorg.springframework.beans.factory.annotation.Value;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Configuration;importorg.springframework.core.io.Resource;importorg.springframework.core.io.support.PathMatchingResourcePatternResolver;importorg.springframework.core.io.support.ResourcePatternResolver;importcom.alibaba.druid.pool.DruidDataSource;@ConfigurationpublicclassMyBatisConfig{@Value("${spring.datasource.url}")privateString jdbcUrl;@Value("${spring.datasource.driverClassName}")privateString jdbcDriverClassName;@Value("${spring.datasource.username}")privateString jdbcUsername;@Value("${spring.datasource.password}")privateString jdbcPassword;@Bean(name ="dataSource",destroyMethod ="close")publicDataSourcedataSource(){    DruidDataSource datasource =newDruidDataSource();// 数据库驱动datasource.setDriverClassName(jdbcDriverClassName);// 相应驱动的jdbcUrldatasource.setUrl(jdbcUrl);// 数据库的用户名datasource.setUsername(jdbcUsername);// 数据库的密码datasource.setPassword(jdbcPassword);// 每个分区最大的连接数datasource.setMaxActive(20);// 每个分区最小的连接数datasource.setMinIdle(5);returndatasource;    }@Bean(name ="sqlSessionFactory")publicSqlSessionFactorysqlSessionFactory(DataSource dataSource){SqlSessionFactoryBean sqlSessionFactoryBean=newSqlSessionFactoryBean();try{sqlSessionFactoryBean.setDataSource(dataSource);// 设置别名包(实体类)sqlSessionFactoryBean.setTypeAliasesPackage("com.xin.dream.pojo");// 设置mybatis的主配置文件ResourcePatternResolver resolver =newPathMatchingResourcePatternResolver();//设置sql配置文件路径sqlSessionFactoryBean.setMapperLocations(resolver.getResources("classpath*:com/xin/dream/mapper/*.xml"));//-- 加载mybatis的全局配置文件  Resource mybatisConfigXml = resolver.getResource("classpath:mybatis/mybatis-config.xml");        sqlSessionFactoryBean.setConfigLocation(mybatisConfigXml);returnsqlSessionFactoryBean.getObject();}catch(Exception e) {// TODO Auto-generated catch blocke.printStackTrace();thrownewRuntimeException(e);}}}

配置Mybatis的Mapper接口类的扫描:

importorg.mybatis.spring.mapper.MapperScannerConfigurer;importorg.springframework.boot.autoconfigure.AutoConfigureAfter;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Configuration;/**

* @instructions 添加mybatis的mapper接口扫描

* @AutoConfigureAfter(MyBatisConfig.class) 很重要,必须在MyBatisConfig配置加载后加载

*/@Configuration@AutoConfigureAfter(MyBatisConfig.class)publicclassMyBatisMapperScannerConfig{@BeanpublicMapperScannerConfigurermapperScannerConfigurer(){MapperScannerConfigurer mapperScannerConfigurer =newMapperScannerConfigurer();mapperScannerConfigurer.setSqlSessionFactoryBeanName("sqlSessionFactory");mapperScannerConfigurer.setBasePackage("com.xin.dream.dao");returnmapperScannerConfigurer;}}

到这就基本完成了,其实就是把以前的xml原封不动的改成java类的形式,把@Configuration看出一个xml文件就是了。加入你们自己的代码就ok了。

中间:“com.xin.dream.pojo”                                    //实体类路径

"classpath*:com/xin/dream/mapper/*.xml"    //sql配置文件的路径

"classpath:mybatis/mybatis-config.xml"         //这个是mybatis全局配置文件路径

"com.xin.dream.dao"                                       //mybatis的mapper接口路径

 改成你们自己的就好。

你可能感兴趣的:(SpringBoot整合mybatis的mybatis-spring的配置方式)