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

        我大概是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接口文件,先弄哪個呢?

相關文章
相關標籤/搜索