作者:一一哥
在上一节中,我带大家学习了Spring Boot中整合JPA,那接下来这一章节中,我继续带领大家学习如何在Spring Boot中整合Mybatis。
MyBatis是一款优秀的持久层框架,它本来是apache的一个开源项目iBatis。在2010年的时候,这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis;2013年11月又迁移到Github。
iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。
支持定制化 SQL、存储过程以及高级映射。
MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。
简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
提供映射标签,支持对象与数据库的orm字段关系映射。
提供对象关系映射标签,支持对象关系组建维护。
提供xml标签,支持编写动态sql。
Mybatis 初期使用比较麻烦,需要各种配置文件、实体类、Dao 层映射关联、还有一大推其它配置。
然后 Mybatis 就发现了这种弊端,为了解决这种弊端,就开发了generator逆向工程,可以根据表结构自动生成实体类、配置文件和 Dao 层代码,可以减轻一部分开发量。
后期也进行了大量的优化,可以使用注解进一步简化开发,自动管理 Dao 层和配置文件等。
到了今天Mybatis进一步简化到极致,那就是mybatis-spring-boot-starter 的出现。我们可以利用 Spring Boot 整合 Mybatis,即使完全不用配置文件,也可以简单配置轻松实现数据库操作。
SpringBoot中整合Mybatis有2种实现方式:
由于注解方式更为简易普遍,所以本案例讲解以注解方式实现的案例。
我们按照之前的经验,创建一个web程序,并将之改造成Spring Boot项目,具体过程略。

org.mybatis.spring.boot
mybatis-spring-boot-starter
2.0.0
mysql
mysql-connector-java
com.alibaba
druid
1.1.10
Spring Boot 会自动加载 spring.datasource.* 相关配置,数据源就会自动注入到 sqlSessionFactory 中,sqlSessionFactory 会自动注入到 Mapper 中。
spring:
datasource:
url: jdbc:mysql://localhost:3306/db4?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&useSSL=true
type: com.alibaba.druid.pool.DruidDataSource
username: root
password: syc
driver-class-name: com.mysql.jdbc.Driver #驱动
mybatis:
type-aliases-package: com.yyg.boot.mapper
spring.datasource.url: 数据库连接字符串;
spring.datasource.username: 数据库用户名;
spring.datasource.password: 数据库密码;
spring.datasource.driver-class-name: 驱动类型(注意MySQL 8.0的值是com.mysql.cj.jdbc.Driver和之前不同);
mybatis.type-aliases-package 配置mapper包名。
用druid提供的DataSource来替换默认的DataSource。
package com.yyg.boot.config;
import com.alibaba.druid.pool.DruidDataSource;
import lombok.Data;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import javax.sql.DataSource;
/**
* @Author 一一哥Sun
* @Date Created in 2020/3/30
* @Description 第二种配置数据源的方式
*/
@Data
@ComponentScan
@Configuration
@ConfigurationProperties(prefix="spring.datasource")
@MapperScan("com.yyg.boot.mapper")
public class DbConfig {
private String url;
private String username;
private String password;
@Bean
public DataSource getDataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setUrl(url);
dataSource.setUsername(username);
dataSource.setPassword(password);
return dataSource;
}
}
可以在这个类上添加@MapperScan("com.yyg.boot.mapper"),指定Mapper接口所在包位置。
package com.yyg.boot.domain;
import lombok.Data;
import lombok.ToString;
/**
* @Author 一一哥Sun
* @Date Created in 2020/3/30
* @Description Description
*/
@Data
@ToString
public class User {
private Long id;
private String username;
private String birthday;
private String sex;
private String address;
}
package com.yyg.boot.mapper;
import com.yyg.boot.domain.User;
import org.apache.ibatis.annotations.*;
/**
* @Author 一一哥Sun
* @Date Created in 2020/3/31
* @Description 在Mybatis的Mapper接口中,增删改查都有对应的注解.@Insert,@Select,@Delete,@Update
*/
public interface UserMapper {
@Select("select * from user where id = #{id}")
User queryUserById(@Param(value = "id") int id);
@Insert("insert into user(username,birthday,sex,address) values(#{username},#{birthday},#{sex},#{address})")
void insertUser(User user);
@Update("UPDATE user SET sex=#{sex} WHERE username=#{username}")
void updateUser(User user);
@Delete("DELETE FROM user WHERE id =#{id}")
void deleteById(@Param("id") int id);
}
Mapper中常用注解
@Select 是查询类的注解,所有的查询均使用这个;
@Result 修饰返回的结果集,关联实体类属性和数据库字段一一对应,如果实体类属性和数据库属性名保持一致,就不需要这个属性来修饰;
@Insert 插入数据库使用,直接传入实体类会自动解析属性到对应的值;
@Update 负责修改,也可以直接传入对象;
@delete 负责删除。
package com.yyg.boot.web;
import com.yyg.boot.domain.User;
import com.yyg.boot.mapper.UserMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
/**
* @Author 一一哥Sun
* @Date Created in 2020/3/31
* @Description Description
*/
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserMapper userMapper;
@GetMapping("/{id}")
public User findUserById(@PathVariable("id") Integer id) {
return userMapper.queryUserById(id);
}
@PostMapping("")
public String addUser(@RequestBody User user) {
userMapper.insertUser(user);
return "success";
}
@PostMapping("/update")
public String updateUser(@RequestBody User user) {
userMapper.updateUser(user);
return "success";
}
@DeleteMapping("/{id}")
public String delUserById(@PathVariable("id") Integer id) {
userMapper.deleteById(id);
return "success";
}
}
注意:
也可以在入口类上添加@MapperScan("com.yyg.boot.mapper"),指定Mapper接口所在包位置。
package com.yyg.boot;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
* @Author 一一哥Sun
* @Date Created in 2020/3/31
* @Description Description
*/
@SpringBootApplication
//@MapperScan("com.yyg.boot.mapper")
public class MybatisApplication {
public static void main(String[] args) {
SpringApplication.run(MybatisApplication.class, args);
}
}
测试添加方法:

可以看到数据库中多了一个id=28的新的记录。