Spring 全家桶之 Spring Boot 2.6.4(四)- Data Access(Part D MyBatis Plus)

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: Spring 全家桶之 Spring Boot 2.6.4(四)- Data Access(Part D MyBatis Plus)

一、Spring Boot 集成 MyBatis Plus

MyBatis Plus是一个MyBatis的增强框架,在MyBatis的基础上只做增强不做改变,为简化开发、提高效率而生。MyBatis Plus提供了通用的Mapper和Service,可以在不编写任何SQL语句的情况下,快速实现对单表的CRUD、批量操作、逻辑删除以及分页等操作。

使用idea创建spring-boot-mybatisplus,导入基本依赖

7803f6d57e444d28ae4513fb1fc32856_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

MyBatis Plus提供了Spring Boot启动器,可以直接导入MyBatis Plus的starter,然后再导入MyBatis Plus代码生成器依赖以及模板依赖

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.1</version>
</dependency>
复制代码

MyBatis Plus 自动配置原理 MyBatis Plus的自动配置类是com.baomidou.mybatisplus.autoconfigure包下的MybatisPlusAutoConfiguration

b1903cbbd9964f2f95f60aa9c77ff67e_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

MybatisPlusAutoConfiguration自动配置类启用了MyBatisPlusProperties配置类

f158544c458140eb86a14e449875de2b_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

MyBatisPlusProperties配置类的前缀是mybatis-plus

abaab7d7cc9a4a08a4ad4201e4a35951_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

mybatis-plus的相关配置都在MyBatisPlusProperties配置类中

二、MyBatis Plus 实现 CRUD

在application.yml中配置数据库连接信息,使用Spring Boot默认的数据源

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    username: root
    password: Abc*123456
    url: jdbc:mysql://rm-uf67r962043910k193o.mysql.rds.aliyuncs.com:3306/test
复制代码

增加MyBatis Plus的相关配置

mybatis-plus:
  mapper-locations: classpath:mappers/*.xml
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    map-underscore-to-camel-case: true
    auto-mapping-behavior: full
复制代码

增加entity包,新增Tesla实体类

@Data
@TableName("t_tesla")
public class Tesla {
    private Integer id;
    private String name;
    private Double price;
    private String vehicleType;
    private String factory;
}
复制代码

新增mapper包,增加TeslaMapper接口,增加selectTeslaById方法

@Mapper
public interface TeslaMapper {
    Tesla selectTeslaById(Integer id);
}
复制代码

在resources目录下增加mpper文件夹,增加TeslaMapper对应的XML文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lilith.mapper.TeslaMapper">
    <sql id="teslaAllColums">
        id,name,price,vehicle_type,factory
    </sql>
    <select id="selectTeslaById" resultType="com.lilith.entity.Tesla">
        SELECT
        <include refid="teslaAllColums"></include>
        FROM t_tesla where id = #{id}
    </select>
</mapper>
复制代码

增加TeslaMapperTest测试类,对selectTeslaById方法进行测试

@SpringBootTest
public class TeslaMapperTest {
    @Resource
    private TeslaMapper teslaMapper;
    @Test
    public void selectTeslaById(){
        Tesla tesla = teslaMapper.selectTeslaById(2);
        System.out.println("查询到的内容为:" + tesla);
    }
}
复制代码

执行该方法

11f9098c9fed406dbfbb378ff3caa01f_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

成功查询到数据,application.yml中MyBatis Plus的配置生效。

继承BaseMapper实现CRUD

TeslaMapper继承MyBatis Plus的BaseMapper接口即可拥有基本CRUD条件查询以及分页方法

@Mapper
public interface TeslaMapper extends BaseMapper<Tesla>{
    Tesla selectTeslaById(Integer id);
}
复制代码

在TeslaMapperTest中测试BaseMapper提供的查询方法

@Test
public void selectOneById(){
    Tesla tesla = teslaMapper.selectById(2);
    System.out.println("MyBatis Plus的SELECT方法查询到的数据:" + tesla);
}
复制代码

执行该方法

07655d90ef0a4807a4e9af6b057108d0_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

更多MyBatis Plus的CRUD方法以及注解和条件查询可以参考Data Acces 之 MyBatis Plus(一)- BaseMapper CRUD(Part A) 和  Data Access 之 MyBatis Plus(二)- Wrapper 条件构造器

三、MyBatis Plus 插件使用

在SSM中配置MyBatis Plus插件需要在Spring 配置文件中配置分页插件,然后将分页插件的Bean注入到MybatisSqlSessionFactoryBean中。而在Spring Boot中可以使用配置类的方式,将分页插件的Bean注册到容器中

新建config包,增加MyBatisPlusConfig配置类,将MyBatis Plus用于分页的插件注入到容器中

@Configuration
public class MyBatisPlusConfig {
    public PaginationInnerInterceptor innerInterceptor(){
        PaginationInnerInterceptor interceptor = new PaginationInnerInterceptor();
        interceptor.setDbType(DbType.MYSQL);
        return interceptor;
    }
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor(){
        MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
        mybatisPlusInterceptor.setInterceptors(Arrays.asList(innerInterceptor()));
        return mybatisPlusInterceptor;
    }
}
复制代码

在TeslaMapperTest中测试selectPage方法

@Test
public void selectPage(){
    Page<Tesla> teslaPage = new Page<>(2,4);
    Page<Tesla> page = teslaMapper.selectPage(teslaPage, null);
    System.out.println("--------------------");
    System.out.println("查询当前页面的数据:" + page.getRecords());
    System.out.println("--------------------");
}
复制代码

执行selectPage方法

image.png

根据输出的SQL语句,成功执行了分页查询。

四、MyBatis Plus MPG 代码生成器

使用MyBatis Plus的代码生成器需要导入generator依赖和模板引擎依赖

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>3.5.1</version>
</dependency>
<dependency>
    <groupId>org.freemarker</groupId>
    <artifactId>freemarker</artifactId>
    <version>2.3.31</version>
</dependency>
复制代码

在MybatisplusApplicationTests测试类中添加代码生成器方法的代码

private static final String JDBC_URL = "jdbc:mysql://localhost/test?useUnicode=true&characterEncoding=utf8&autoReconnect=true&useSSL=false&serverTimezone=Asia/Shanghai&allowMultiQueries=true";
private static final String JDBC_USERNAME = "root";
private static final String JDBC_PASSWORD = "root";
// 代码生成器
@Test
public void generator(){
    FastAutoGenerator.create(JDBC_URL, JDBC_USERNAME, JDBC_PASSWORD)
            .globalConfig(builder -> {
                builder.author("Jingnan") // 设置作者
                        //.enableSwagger() // 开启 swagger 模式
                        .fileOverride() // 覆盖已生成文件
                        .outputDir("src/main/java"); // 指定输出目录
            })
            .packageConfig(builder -> {
                builder.parent("com") // 设置父包名
                        .moduleName("lilith") // 设置父包模块名
                        .pathInfo(Collections.singletonMap(OutputFile.mapperXml, "src/main/resources/mappers/")); // 设置mapperXml生成路径
            })
            .strategyConfig(builder -> {
                builder.addInclude("porsche") // 设置需要生成的表名
                        .addTablePrefix("t_", "c_"); // 设置过滤表前缀
            })
            .templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
            .execute();
}
复制代码

执行该方法就可以生成controller层、service层、mapper层以及mapper XML配置文件

image.png

测试Controller层代码

在PorscheController中增加代码

@Controller
@RequestMapping("/lilith/porsche")
public class PorscheController {
    @Autowired
    private IPorscheService porscheService;
    @ResponseBody
    @GetMapping("/list")
    public List<Porsche> list(){
        List<Porsche> list = porscheService.list();
        return list;
    }
}
复制代码

将TeslaMapper类上的@Mapper注解删除,在MyBatisplusApplication启动类上添加@MapperScan注解

@MapperScan(basePackages = "com.lilith.mapper")
复制代码

启动应用,浏览器输入 http://localhost:8080/lilith/porsche/list

image.png

关于MyBatis Plus的代码生成器以及Mapper层和Service层的测试也可以参考Data Access 之 MyBatis Plus(三)- MPG代码生成器


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
5月前
|
前端开发 Java 应用服务中间件
《深入理解Spring》 Spring Boot——约定优于配置的革命者
Spring Boot基于“约定优于配置”理念,通过自动配置、起步依赖、嵌入式容器和Actuator四大特性,简化Spring应用的开发与部署,提升效率,降低门槛,成为现代Java开发的事实标准。
|
5月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
5月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
595 2
|
6月前
|
人工智能 Java 机器人
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
Spring AI Alibaba集成Ollama,基于Java构建本地大模型应用,支持流式对话、knife4j接口可视化,实现高隐私、免API密钥的离线AI服务。
5019 2
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
存储 JSON Java
747 0
|
5月前
|
Java 测试技术 数据库连接
【SpringBoot(四)】还不懂文件上传?JUnit使用?本文带你了解SpringBoot的文件上传、异常处理、组件注入等知识!并且带你领悟JUnit单元测试的使用!
Spring专栏第四章,本文带你上手 SpringBoot 的文件上传、异常处理、组件注入等功能 并且为你演示Junit5的基础上手体验
1036 3
|
5月前
|
JavaScript Java Maven
【SpringBoot(二)】带你认识Yaml配置文件类型、SpringMVC的资源访问路径 和 静态资源配置的原理!
SpringBoot专栏第二章,从本章开始正式进入SpringBoot的WEB阶段开发,本章先带你认识yaml配置文件和资源的路径配置原理,以方便在后面的文章中打下基础
492 4
|
8月前
|
缓存 JSON 前端开发
第07课:Spring Boot集成Thymeleaf模板引擎
第07课:Spring Boot集成Thymeleaf模板引擎
742 0
第07课:Spring Boot集成Thymeleaf模板引擎
|
8月前
|
Java Spring 容器
SpringBoot自动配置的原理是什么?
Spring Boot自动配置核心在于@EnableAutoConfiguration注解,它通过@Import导入配置选择器,加载META-INF/spring.factories中定义的自动配置类。这些类根据@Conditional系列注解判断是否生效。但Spring Boot 3.0后已弃用spring.factories,改用新格式的.imports文件进行配置。
1205 0
|
9月前
|
人工智能 Java 测试技术
Spring Boot 集成 JUnit 单元测试
本文介绍了在Spring Boot中使用JUnit 5进行单元测试的常用方法与技巧,包括添加依赖、编写测试类、使用@SpringBootTest参数、自动装配测试模块(如JSON、MVC、WebFlux、JDBC等),以及@MockBean和@SpyBean的应用。内容实用,适合Java开发者参考学习。
987 0

热门文章

最新文章