我大概是15年初的時候,接觸了SpringBoot,不過只開發了一個小項目,就沒再使用過。時隔兩年,SpringBoot變的熱火朝天,我也不得不認真學習一下了,如下我的心得,願對新手有所幫助。java
SpringBoot集成MyBatis有兩種方式,一種簡單的方式就是使用MyBatis官方提供的:
mybatis-spring-boot-starter
另一種方式也是我推薦的整合方式: 就是仍然用相似mybatis-spring的配置方式,這種方式須要本身寫一些代碼,可是能夠很方便的控制MyBatis的各項配置。mysql
①:在http://start.spring.io/,配置你的項目信息並下載,個人是《1.5.9.RELEASE》最初的應該以下圖:
web
②:在POM文件中加,整合的最基礎的包,包版本大家本身定spring
<!-- 由於是web應用程序,aop.beans,web,mvc等都再也不須要導入了,並自動完成組件配置 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <!-- Mybatis --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>${mybatis-spring.version}</version> </dependency> <dependency> <groupId>org.mybatis.caches</groupId> <artifactId>mybatis-ehcache</artifactId> <version>${mybatis-ehcache.version}</version> </dependency> <!-- MySql --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <!-- 阿里 鏈接池 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>${druid.version}</version> </dependency>
個人包版本:sql
<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> <mybatis.version>3.4.5</mybatis.version> <mybatis-spring.version>1.3.1</mybatis-spring.version> <mybatis-ehcache.version>1.1.0</mybatis-ehcache.version> <mysql-connector-java.version>5.1.45</mysql-connector-java.version> <druid.version>1.1.6</druid.version> </properties>
配置application.properties,不少人用的application.yml,可是我認爲application.yml文件快速檢索很麻煩,東西多了找一個元素很蛋疼,也許我還沒領悟到yml的優點。因此我也仍是用之前的.properties的配置文件,以下:數據庫
spring.datasource.driverClassName = com.mysql.jdbc.Driver spring.datasource.url = jdbc:mysql://192.168.1.206:3306/community?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&failOverReadOnly=false spring.datasource.username = root spring.datasource.password = 1234
重點來了,整合Mybatis,配置dataSoure,和sqlSessionFactory:apache
import javax.sql.DataSource; import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.core.io.Resource; import org.springframework.core.io.support.PathMatchingResourcePatternResolver; import org.springframework.core.io.support.ResourcePatternResolver; import com.alibaba.druid.pool.DruidDataSource; @Configuration public class MyBatisConfig { @Value("${spring.datasource.url}") private String jdbcUrl; @Value("${spring.datasource.driverClassName}") private String jdbcDriverClassName; @Value("${spring.datasource.username}") private String jdbcUsername; @Value("${spring.datasource.password}") private String jdbcPassword; @Bean(name = "dataSource",destroyMethod = "close") public DataSource dataSource() { DruidDataSource datasource = new DruidDataSource(); // 數據庫驅動 datasource.setDriverClassName(jdbcDriverClassName); // 相應驅動的jdbcUrl datasource.setUrl(jdbcUrl); // 數據庫的用戶名 datasource.setUsername(jdbcUsername); // 數據庫的密碼 datasource.setPassword(jdbcPassword); // 每一個分區最大的鏈接數 datasource.setMaxActive(20); // 每一個分區最小的鏈接數 datasource.setMinIdle(5); return datasource; } @Bean(name = "sqlSessionFactory") public SqlSessionFactory sqlSessionFactory(DataSource dataSource) { SqlSessionFactoryBean sqlSessionFactoryBean=new SqlSessionFactoryBean(); try { sqlSessionFactoryBean.setDataSource(dataSource); // 設置別名包(實體類) sqlSessionFactoryBean.setTypeAliasesPackage("com.xin.dream.pojo"); // 設置mybatis的主配置文件 ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); //設置sql配置文件路徑 sqlSessionFactoryBean.setMapperLocations(resolver.getResources("classpath*:com/xin/dream/mapper/*.xml")); //-- 加載mybatis的全局配置文件 Resource mybatisConfigXml = resolver.getResource("classpath:mybatis/mybatis-config.xml"); sqlSessionFactoryBean.setConfigLocation(mybatisConfigXml); return sqlSessionFactoryBean.getObject(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); throw new RuntimeException(e); } } }
配置Mybatis的Mapper接口類的掃描:session
import org.mybatis.spring.mapper.MapperScannerConfigurer; import org.springframework.boot.autoconfigure.AutoConfigureAfter; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; /** * @instructions 添加mybatis的mapper接口掃描 * * @PS @AutoConfigureAfter(MyBatisConfig.class): * 不少文章,和培訓老師講課,都說必須的加這個註釋 * 結果我也就入坑了,其實這個註釋是沒的做用的, */ @Configuration /*@AutoConfigureAfter(MyBatisConfig.class) */ public class MyBatisMapperScannerConfig { @Bean public MapperScannerConfigurer mapperScannerConfigurer() { MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer(); mapperScannerConfigurer.setSqlSessionFactoryBeanName("sqlSessionFactory"); mapperScannerConfigurer.setBasePackage("com.xin.dream.dao"); return mapperScannerConfigurer; } }
到這就基本完成了,其實就是把之前的xml原封不動的改爲java類的形式,把@Configuration看出一個xml文件就是了。加入大家本身的代碼就ok了。mybatis
中間:「com.xin.dream.pojo」 //實體類路徑
"classpath*:com/xin/dream/mapper/*.xml" //sql配置文件的路徑
"classpath:mybatis/mybatis-config.xml" //這個是mybatis全局配置文件路徑
"com.xin.dream.dao" //mybatis的mapper接口路徑
改爲大家本身的就好。mvc
到這就結束了,一直打。結束,如今就要打;;;;;;;;;;;;;;;;;;
走你:hello world!!!
後面我會寫SpringBoot的分頁插件整合,多數據源事務整合。
與不用sqlsqlSessionFactory整合方式改用SqlSessionTemplate的配置方式,因此操做公用一個dao接口文件,先弄哪個呢?