spring boot 整合 mybatis 以及原理

时间:2022-09-25 23:12:17

同上一篇文章一样,spring boot 整合 mybatis过程中没有看见SqlSessionFactory,sqlsession(sqlsessionTemplate),就连在spring框架整合 mybatis时的SqlSessionFactoryBean都没看到,那spring boot 把这些参数都放在了 mybatis-spring boot autoconfigure.jar 包中的MybatisAutoConfiguration 这个类中,使用 @ConditionalOnMissingBean这个注解,当环境中缺少 sqlsessionFactory sqlsessionTemplate时会自动注入

Example

使用spring boot 的starter pom

需要导入 mybatis-spring-boot-starter 和 数据库连接相关的配置

pom.xml

  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  2. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  3. <modelVersion>4.0.0</modelVersion>
  4. <groupId>com.ibigsea</groupId>
  5. <artifactId>bootdao</artifactId>
  6. <version>0.0.1-SNAPSHOT</version>
  7. <packaging>jar</packaging>
  8. <name>bootdao</name>
  9. <url>http://maven.apache.org</url>
  10. <properties>
  11. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  12. <boot.version>1.3.1.RELEASE</boot.version>
  13. </properties>
  14. <dependencies>
  15. <dependency>
  16. <groupId>org.springframework.boot</groupId>
  17. <artifactId>spring-boot-starter-web</artifactId>
  18. <version>${boot.version}</version>
  19. </dependency>
  20. <dependency>
  21. <groupId>org.mybatis.spring.boot</groupId>
  22. <artifactId>mybatis-spring-boot-starter</artifactId>
  23. <version>1.1.1</version>
  24. </dependency>
  25. <!-- mysql 驱动 -->
  26. <dependency>
  27. <groupId>mysql</groupId>
  28. <artifactId>mysql-connector-java</artifactId>
  29. <version>5.1.38</version>
  30. </dependency>
  31. <!-- 数据库连接池 -->
  32. <dependency>
  33. <groupId>com.alibaba</groupId>
  34. <artifactId>druid</artifactId>
  35. <version>1.0.5</version>
  36. </dependency>
  37. <dependency>
  38. <groupId>org.springframework.boot</groupId>
  39. <artifactId>spring-boot-starter-test</artifactId>
  40. <version>${boot.version}</version>
  41. <scope>test</scope>
  42. </dependency>
  43. </dependencies>
  44. <build>
  45. <plugins>
  46. <plugin>
  47. <groupId>org.springframework.boot</groupId>
  48. <artifactId>spring-boot-maven-plugin</artifactId>
  49. </plugin>
  50. </plugins>
  51. </build>
  52. </project>

是不是很方便,mybatis的starter pom里面依赖了mybatis和spring相关的jar

只需导入一个就OK了

spring boot 整合 mybatis 以及原理

这里采用的是阿里巴巴的druid数据连接池

为了方便使用 yml配置文件

application.yml

  1. ---
  2. spring:
  3. profiles : dev
  4. datasource:
  5. name: mydb
  6. type: com.alibaba.druid.pool.DruidDataSource
  7. url: jdbc:mysql://127.0.0.1:3306/mytestdb
  8. username: root
  9. password: 123456
  10. driver-class-name: com.mysql.jdbc.Driver
  11. minIdle: 1
  12. maxActive: 2
  13. initialSize: 1
  14. timeBetweenEvictionRunsMillis: 3000
  15. minEvictableIdleTimeMillis: 300000
  16. validationQuery: SELECT 'ZTM' FROM DUAL
  17. testWhileIdle: true
  18. testOnBorrow: false
  19. testOnReturn: false
  20. mybatis:
  21. mapperLocations: classpath*:com/ibigsea/bootdao/mapper/*.xml
  22. typeAliasesPackage: com.ibigsea.bootdao.entity

User.java

  1. package com.ibigsea.bootdao.entity;
  2. import java.io.Serializable;
  3. public class User implements Serializable {
  4. private static final long serialVersionUID = 8809101560720973267L;
  5. private Integer id;
  6. private String userName;
  7. private Integer age;
  8. public Integer getId() {
  9. return id;
  10. }
  11. public void setId(Integer id) {
  12. this.id = id;
  13. }
  14. public String getUserName() {
  15. return userName;
  16. }
  17. public void setUserName(String userName) {
  18. this.userName = userName;
  19. }
  20. public Integer getAge() {
  21. return age;
  22. }
  23. public void setAge(Integer age) {
  24. this.age = age;
  25. }
  26. @Override
  27. public String toString() {
  28. return "User [id=" + id + ", userName=" + userName + ", age=" + age + "]";
  29. }
  30. }

UserMapper.java

  1. package com.ibigsea.bootdao.mapper;
  2. import java.util.List;
  3. import org.apache.ibatis.annotations.Mapper;
  4. import com.ibigsea.bootdao.entity.User;
  5. @Mapper
  6. public interface UserMapper {
  7. int save(User user);
  8. User selectById(Integer id);
  9. int updateById(User user);
  10. int deleteById(Integer id);
  11. List<User> queryAll();
  12. }
  1. <p>UserMapper.xml</p>
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
  3. <mapper namespace="com.ibigsea.bootdao.mapper.UserMapper" >
  4. <insert id="save" parameterType="com.ibigsea.bootdao.entity.User">
  5. insert into t_user(username,age) values(#{userName,jdbcType=VARCHAR},#{age,jdbcType=NUMERIC})
  6. </insert>
  7. <select id="selectById" resultType="com.ibigsea.bootdao.entity.User">
  8. select * from t_user where id = #{id,jdbcType=NUMERIC}
  9. </select>
  10. <update id="updateById" parameterType="com.ibigsea.bootdao.entity.User">
  11. update t_user set
  12. username = #{userName,jdbcType=VARCHAR} ,
  13. age = #{age,jdbcType=NUMERIC}
  14. where id = #{id,jdbcType=NUMERIC}
  15. </update>
  16. <delete id="deleteById">
  17. delete from t_user where id = #{id,jdbcType=NUMERIC}
  18. </delete>
  19. <select id="queryAll" resultType="com.ibigsea.bootdao.entity.User">
  20. select * from t_user
  21. </select>
  22. </mapper>

启动类 App.class

  1. package com.ibigsea.bootdao;
  2. import org.springframework.boot.autoconfigure.SpringBootApplication;
  3. /**
  4. * Hello world!
  5. *
  6. */
  7. @SpringBootApplication
  8. //启注解事务管理
  9. @EnableTransactionManagement
  10. public class App {
  11. public static void main(String[] args) {
  12. System.out.println("Hello World!");
  13. }
  14. }

这里使用test来测试

  1. package com.ibigsea.bootdao;
  2. import org.junit.Test;
  3. import org.junit.runner.RunWith;
  4. import org.springframework.beans.factory.annotation.Autowired;
  5. import org.springframework.boot.test.SpringApplicationConfiguration;
  6. import org.springframework.test.context.ActiveProfiles;
  7. import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
  8. import com.ibigsea.bootdao.entity.User;
  9. import com.ibigsea.bootdao.mapper.UserMapper;
  10. @RunWith(SpringJUnit4ClassRunner.class)
  11. @SpringApplicationConfiguration(classes = {App.class})
  12. //相当于  --spring.profiles.active=dev
  13. @ActiveProfiles(value="dev")
  14. public class AppTest {
  15. @Autowired
  16. private UserMapper mapper;
  17. @Test
  18. public void testInsert(){
  19. User user = new User();
  20. user.setUserName("张三");
  21. user.setAge(23);
  22. mapper.save(user);
  23. System.out.println("插入用户信息"+user.getUserName());
  24. }
  25. }

运行结果:

spring boot 整合 mybatis 以及原理

Ok 数据库这边也有数据了

spring boot 整合 mybatis 以及原理

表结构这边就不提供了 , 就一个很简单的表 自己创建一个就可以了

查询:

  1. @Test
  2. public void testSelect(){
  3. User user = mapper.selectById(1);
  4. System.out.println(user);
  5. }

spring boot 整合 mybatis 以及原理
update

  1. @Test
  2. public void testUpdate(){
  3. User user = mapper.selectById(1);
  4. System.out.println(user);
  5. user.setAge(24);
  6. mapper.updateById(user);
  7. user = mapper.selectById(1);
  8. System.out.println(user);
  9. }

spring boot 整合 mybatis 以及原理

Mybatis相关的配置

spring boot 整合 mybatis 以及原理

MybatisAutoConfiguration

Spring boot 在运行的时候会进行自动配置

读取到 mybatis-spring-boot-autoconfigure 里面的spring.factories,然后自动配置

就是下面这个类

spring boot 整合 mybatis 以及原理

spring boot 整合 mybatis 以及原理

这个方法使用了PostConstruct注解,在初始化的时候去加载mybatis的配置文件,然后创建SqlSessionFactory

spring boot 整合 mybatis 以及原理

spring boot 整合 mybatis 以及原理

Mybatis自动配置会自动创建 sqlSessionFactorySqlSessionTemplate

spring boot 整合 mybatis 以及原理

这个东西 就是 加载在注解了@Mapper的类

如果不喜欢在mapper上面加注解的话,也可以通过@MapperScan

spring boot 整合 mybatis 以及原理

这样子:

spring boot 整合 mybatis 以及原理

这样就OK啦

关于事务方面

在启动类上面添加

@EnableTransactionManagement注解

然后在类上面或者方法上面添加@Transactional注解

  1. package com.ibigsea.bootdao.service;
  2. import org.springframework.beans.factory.annotation.Autowired;
  3. import org.springframework.stereotype.Service;
  4. import org.springframework.transaction.annotation.Transactional;
  5. import com.ibigsea.bootdao.entity.User;
  6. import com.ibigsea.bootdao.mapper.UserMapper;
  7. @Service("userService")
  1. //在方法和类上面都可以
  2. @Transactional
  3. public class UserService {
  4. @Autowired
  5. private UserMapper mapper;
  6. public void insetUser() throws Exception {
  7. User user = new User();
  8. user.setUserName("李四");
  9. user.setAge(23);
  10. mapper.save(user);
  11. System.out.println("插入用户信息"+user.getUserName());
  12. if (user.getUserName().equals("李四")) {
  13. throw new IllegalArgumentException("出现异常QAQ");
  14. }
  15. user = new User();
  16. user.setUserName("李四11111");
  17. user.setAge(23);
  18. mapper.save(user);
  19. }
  20. }

测试类

  1. @RunWith(SpringJUnit4ClassRunner.class)
  2. @SpringApplicationConfiguration(classes = {App.class})
  3. //相当于  --spring.profiles.active=dev
  4. @ActiveProfiles(value="dev")
  5. @EnableTransactionManagement
  6. public class AppTest {
  7. @Autowired
  8. private UserService userService;
  9. @Test
  10. public void testTransactional() throws Exception {
  11. userService.insetUser();
  12. }
  13. }

spring boot 整合 mybatis 以及原理

数据库结果

spring boot 整合 mybatis 以及原理

我们吧@Transactional注解去掉 或者去掉 @EnableTransactionManagement注解

测试下看看

spring boot 整合 mybatis 以及原理

数据被插入~~~~~

spring boot 整合 mybatis 以及原理的更多相关文章

  1. Spring Boot系列(三):Spring Boot整合Mybatis源码解析

    一.Mybatis回顾 1.MyBatis介绍 Mybatis是一个半ORM框架,它使用简单的 XML 或注解用于配置和原始映射,将接口和Java的POJOs(普通的Java 对象)映射成数据库中的记 ...

  2. Spring Boot整合Mybatis并完成CRUD操作

    MyBatis 是一款优秀的持久层框架,被各大互联网公司使用,本文使用Spring Boot整合Mybatis,并完成CRUD操作. 为什么要使用Mybatis?我们需要掌握Mybatis吗? 说的官 ...

  3. Spring Boot 整合mybatis时遇到的mapper接口不能注入的问题

    现实情况是这样的,因为在练习spring boot整合mybatis,所以自己新建了个项目做测试,可是在idea里面mapper接口注入报错,后来百度查询了下,把idea的注入等级设置为了warnin ...

  4. Spring Boot整合Mybatis报错InstantiationException&colon; tk&period;mybatis&period;mapper&period;provider&period;base&period;BaseSelectProvider

    Spring Boot整合Mybatis时一直报错 后来发现原来主配置类上的MapperScan导错了包 由于我使用了通用Mapper,所以应该导入通用mapper这个包

  5. Spring Boot整合MyBatis&lpar;非注解版&rpar;

    Spring Boot整合MyBatis(非注解版),开发时采用的时IDEA,JDK1.8 直接上图: 文件夹不存在,创建一个新的路径文件夹 创建完成目录结构如下: 本人第一步习惯先把需要的包结构创建 ...

  6. Spring Boot整合Mybatis完成级联一对多CRUD操作

    在关系型数据库中,随处可见表之间的连接,对级联的表进行增删改查也是程序员必备的基础技能.关于Spring Boot整合Mybatis在之前已经详细写过,不熟悉的可以回顾Spring Boot整合Myb ...

  7. 太妙了!Spring boot 整合 Mybatis Druid,还能配置监控?

    Spring boot 整合 Mybatis Druid并配置监控 添加依赖 <!--druid--> <dependency> <groupId>com.alib ...

  8. Spring Boot 整合 Mybatis 实现 Druid 多数据源详解

    摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢! “清醒时做事,糊涂时跑步,大怒时睡觉,独处时思考” 本文提纲一.多数据源的应用场景二.运行 sp ...

  9. Spring boot整合Mybatis

    时隔两个月的再来写博客的感觉怎么样呢,只能用“棒”来形容了.闲话少说,直接入正题,之前的博客中有说过,将spring与mybatis整个后开发会更爽,基于现在springboot已经成为整个业界开发主 ...

随机推荐

  1. Session监听器

    Session监听器,是用来监听session对象创建和关闭的.有时我们需要在session创建或关闭时执行一些操作.这是就可以使用Session Listenner. .在项目的web.xml文件中 ...

  2. QTabWiget Change Color 改变颜色

    Qt中的QTabWiget 类提供了一个标签控件,但是这个控件默认初始化的颜色是白色,和原窗口的颜色不同,看起来非常的违和,所以我们希望将其的背景颜色设为当前窗口的背景颜色.我们所要做的就是先将应用程 ...

  3. ExpandableListView 箭头靠右

    ExpandableListView 默认标示箭头是在左边的,当左边有图片时,不是太好看,想把它放在右边,这么简单的事可我折腾死了,还好给我找到了. 参照了以下链接: expandableListvi ...

  4. JDK的安装

    安装jdk解压拷贝过来的jdk(1.6版本)压缩包 cd /usr/local/tar xzvf /tmp/jdk.tgz 修改环境变量vi /etc/profile 加入如下内容export JAV ...

  5. 学习笔记1&lowbar;Day09&lowbar;Servlet

    生命周期方法: l  void init(ServletConfig):出生之后(1次): l  void service(ServletRequest request, ServletRespons ...

  6. 微信小程序之滑动日历展示

    滑动日历效果 效果预览 实现要求:顶部固定悬浮的是获取未来一周的日期,分为上下两部分,上面部分显示星期,下面则显示具体日期.今天则显示今天,可点击头部具体日期,可向左向右滑动. 实现代码 顶部日历 页 ...

  7. 利用GitLab webhook来实现触发Jenkins自动操作

    本文针对如何设置GitLab以及Jenkins,实现每次GitLab上有提交事件的时候,都能触发Jenkins执行相应的操作,主要分为以下几个步骤: 1.新建GitLab测试用例 进入个人GitLab ...

  8. 非对称加密算法-RSA算法

    一.概述 1.RSA是基于大数因子分解难题.目前各种主流计算机语言都支持RSA算法的实现 2.java6支持RSA算法 3.RSA算法可以用于数据加密和数字签名 4.RSA算法相对于DES/AES等对 ...

  9. Lua搜索特殊字符

    local newtext = "." local index1 = string.find(newtext,"%.") 在这里,"."是通 ...

  10. vs2013未找到与约束匹配的导出

    解决方法: 1.关闭VS: 2.去C:/Users/<your users name>/AppData/Local/Microsoft/VisualStudio/12.0/Componen ...