文档章节

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

边鹏_尛爺鑫
 边鹏_尛爺鑫
发布于 2018/01/05 14:51
字数 1001
阅读 3353
收藏 25

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

        SpringBoot集成MyBatis有两种方式,一种简单的方式就是使用MyBatis官方提供的:
                  mybatis-spring-boot-starter
        另外一种方式也是我推荐的整合方式:                                                                                                     就是仍然用类似mybatis-spring的配置方式,这种方式需要自己写一些代码,但是可以很方便的控制MyBatis的各项配置。

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

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

        <!-- 因为是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>

我的包版本:

   <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:

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接口类的扫描:

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了。

        中间:“com.xin.dream.pojo”                                    //实体类路径
                    "classpath*:com/xin/dream/mapper/*.xml"    //sql配置文件的路径
                    "classpath:mybatis/mybatis-config.xml"         //这个是mybatis全局配置文件路径
                    "com.xin.dream.dao"                                       //mybatis的mapper接口路径
        改成你们自己的就好。

到这就结束了,一直打结束,现在就要打;;;;;;;;;;;;;;;;;;

走你:hello world!!!

后面我会写SpringBoot的分页插件整合,多数据源事务整合。

与不用sqlsqlSessionFactory整合方式改用SqlSessionTemplate的配置方式,所以操作公用一个dao接口文件,先弄哪一个呢?

© 著作权归作者所有

共有 人打赏支持
边鹏_尛爺鑫
粉丝 29
博文 32
码字总数 25997
作品 0
成都
程序员
私信 提问
加载中

评论(16)

J
Jervain

引用来自“youngkun”的评论

引用来自“边鹏_尛爺鑫”的评论

引用来自“youngkun”的评论

引用来自“边鹏_尛爺鑫”的评论

引用来自“youngkun”的评论

注释里,“很重要”,那句话一点都不重要,因为此时你的这个注解根本无效
什么是注释?注释的作用是什么?无效就不注释了?

@边鹏_尛爺鑫 我是说 @AutoConfigureAfter(MyBatisConfig.class)在此时是无效的,这个bean先于MyBatisConfig初始化,加上注解无效
你是说这个@AutoConfigureAfter没起到作用是吧,不是吧,报错了吗?

@边鹏_尛爺鑫 不报错啊,只是说此时你说的这个很重要是多余的,这个注解此时是无效的,你看看MapperScannerConfigurer继承类和实现接口就明白了,会导致MapperScannerConfigurerConfig优先于MybatisConfig初始化,你可以分别在两个类打断掉,启动时看先执行哪个
我打了断点执行后确实是没起到作用,请问下为什么会这样呢,我看了继承关系没弄懂
边鹏_尛爺鑫
边鹏_尛爺鑫

引用来自“youngkun”的评论

引用来自“边鹏_尛爺鑫”的评论

引用来自“youngkun”的评论

引用来自“边鹏_尛爺鑫”的评论

引用来自“youngkun”的评论

注释里,“很重要”,那句话一点都不重要,因为此时你的这个注解根本无效
什么是注释?注释的作用是什么?无效就不注释了?

@边鹏_尛爺鑫 我是说 @AutoConfigureAfter(MyBatisConfig.class)在此时是无效的,这个bean先于MyBatisConfig初始化,加上注解无效
你是说这个@AutoConfigureAfter没起到作用是吧,不是吧,报错了吗?

@边鹏_尛爺鑫 不报错啊,只是说此时你说的这个很重要是多余的,这个注解此时是无效的,你看看MapperScannerConfigurer继承类和实现接口就明白了,会导致MapperScannerConfigurerConfig优先于MybatisConfig初始化,你可以分别在两个类打断掉,启动时看先执行哪个

回复@youngkun : 哦哦,谢谢,我去看看
y
youngkun

引用来自“边鹏_尛爺鑫”的评论

引用来自“youngkun”的评论

引用来自“边鹏_尛爺鑫”的评论

引用来自“youngkun”的评论

注释里,“很重要”,那句话一点都不重要,因为此时你的这个注解根本无效
什么是注释?注释的作用是什么?无效就不注释了?

@边鹏_尛爺鑫 我是说 @AutoConfigureAfter(MyBatisConfig.class)在此时是无效的,这个bean先于MyBatisConfig初始化,加上注解无效
你是说这个@AutoConfigureAfter没起到作用是吧,不是吧,报错了吗?

@边鹏_尛爺鑫 不报错啊,只是说此时你说的这个很重要是多余的,这个注解此时是无效的,你看看MapperScannerConfigurer继承类和实现接口就明白了,会导致MapperScannerConfigurerConfig优先于MybatisConfig初始化,你可以分别在两个类打断掉,启动时看先执行哪个
边鹏_尛爺鑫
边鹏_尛爺鑫

引用来自“youngkun”的评论

引用来自“边鹏_尛爺鑫”的评论

引用来自“youngkun”的评论

注释里,“很重要”,那句话一点都不重要,因为此时你的这个注解根本无效
什么是注释?注释的作用是什么?无效就不注释了?

@边鹏_尛爺鑫 我是说 @AutoConfigureAfter(MyBatisConfig.class)在此时是无效的,这个bean先于MyBatisConfig初始化,加上注解无效
你是说这个@AutoConfigureAfter没起到作用是吧,不是吧,报错了吗?
y
youngkun

引用来自“边鹏_尛爺鑫”的评论

引用来自“youngkun”的评论

注释里,“很重要”,那句话一点都不重要,因为此时你的这个注解根本无效
什么是注释?注释的作用是什么?无效就不注释了?

@边鹏_尛爺鑫 我是说 @AutoConfigureAfter(MyBatisConfig.class)在此时是无效的,这个bean先于MyBatisConfig初始化,加上注解无效
边鹏_尛爺鑫
边鹏_尛爺鑫

引用来自“youngkun”的评论

注释里,“很重要”,那句话一点都不重要,因为此时你的这个注解根本无效
什么是注释?注释的作用是什么?无效就不注释了?
y
youngkun
注释里,“很重要”,那句话一点都不重要,因为此时你的这个注解根本无效
流行雨
流行雨
感觉更加灵活,想怎么改,就怎么改
流行雨
流行雨
我也比较喜欢,类配置的方式,不怎么用mybatis官方的包
边鹏_尛爺鑫
边鹏_尛爺鑫
异步处理数据,数据之间不存在事务的,处理方案太多了
SpringBoot 学习二:操作数据库

本文将从以下几个方面介绍: 前言 配置数据源 SpringBoot 整合 Mybatis SpringBoot 整合 JdbcTemplate SpringBoot 整合 Redis 前言 在上篇文章 SpringBoot 学习一 中已经学习了 SpringBoot的...

tsmyk0715
2018/09/26
0
0
玩转springboot:整合mybatis实例

这篇文章讲解一下springboot整合mybatis,其实,springboot整合mybatis和springmvc整合mybatis并没有什么太大的区别,大体上还是差不多哦,只是比springmvc更加的简单一点,下面我们就以一个...

java知识分子
2018/10/30
0
0
springboot从入门到精通教程分享, 深度掌握Springboot实践技术教程

深度掌握Springboot实践技术教程,共22个课时,需要的可回复邮箱。 课程简介 day1 01springboot简介-曾经开发中的问题 02springboot解决的问题-优势以及弊端 03springboot环境准备 04spring...

小小倾听
2018/12/06
0
0
Spring Boot学习资源

Spring Boot 入门 http://blog.csdn.net/isea533/article/details/50278205 ---------------------------------------------------------- Spring Boot 静态资源处理 http://blog.csdn.net/c......

IamOkay
2017/02/17
0
0
Spring Boot学习笔记

多模块开发 [SpringBoot学习]-IDEA创建Gradle多Module结构的SpringBoot项目 RabbitMQ RabbitMQ 安装 linux安装RabbitMQ详细教程 Ubuntu 16.04 RabbitMq 安装与运行(安装篇) ubantu安装...

OSC_fly
2018/07/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Linux Wireshark普通用户启动使用方案

当系统安装好Wireshark后请正常启动是否可以进行正常使用,如果不行请参考下列指导 向系统添加一个用户组 sudo groupadd wireshark //如提示此组存在可跳过 将指定用户添加到这个组中 sudo...

CHONGCHEN
今天
1
0
CSS 选择器参考手册

CSS 选择器参考手册 选择器 描述 [attribute] 用于选取带有指定属性的元素。 [attribute=value] 用于选取带有指定属性和值的元素。 [attribute~=value] 用于选取属性值中包含指定词汇的元素。...

Jack088
今天
2
0
数据库篇一

数据库篇 第1章 数据库介绍 1.1 数据库概述  什么是数据库(DB:DataBase) 数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以对数据库中的数据...

stars永恒
今天
4
0
Intellij IDEA中设置了jsp页面,但是在访问页面时却提示404

在Intellij IDEA中设置了spring boot的jsp页面,但是在访问时,却出现404,Not Found,经过查找资料后解决,步骤如下: 在Run/Debug Configurations面板中设置该程序的Working Directory选项...

uknow8692
昨天
4
0
day24:文档第五行增内容|每月1号压缩/etc/目录|过滤文本重复次数多的10个单词|人员分组|

1、在文本文档1.txt里第五行下面增加如下内容;两个方法; # This is a test file.# Test insert line into this file. 分析:给文档后增加内容,可以用sed 来搞定;也可以用while do done...

芬野de博客
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部