java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Spring Boot 3.0+MyBatis-Plus全家桶

Spring Boot 3.0 + MyBatis-Plus全家桶实战详细代码

作者:云起川南

MyBatis-Plus是一个MyBatis的增强工具,是国内人员开发的MyBatis增强工具,在MyBatis的基础上只做增强不做改变,为简化开发、提高效率而生,这篇文章主要介绍了Spring Boot 3.0 + MyBatis-Plus全家桶的相关资料,需要的朋友可以参考下

概要

从依赖、配置、实体/Mapper、分页、常用插件(逻辑删除、乐观锁)、以及简单的示例接口讲起。代码可直接复制到项目里跑通。文中引用 MyBatis-Plus 官方与社区资料以保证兼容性与最佳实践。

1. 项目说明与目标

目标:在 Spring Boot 3.0 项目中集成 MyBatis-Plus,实现标准的增删改查、分页与常见插件(逻辑删除、乐观锁),并演示一个可运行的示例接口供快速上手。MyBatis-Plus 官方提供 Spring Boot 3 的 starter,且社区维护活跃

2. 快速依赖(Maven)

pom.xml 关键依赖(只展示最重要的部分):

<properties>
    <java.version>17</java.version>
    <spring-boot.version>3.0.8</spring-boot.version> <!-- 任选 Spring Boot 3.0.x -->
    <mybatis-plus.version>3.5.12</mybatis-plus.version> <!-- 官方 Maven 中央库示例版本 -->
</properties>

<dependencies>
    <!-- Spring Boot Starter Web -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- Spring Boot Starter JDBC / DataSource -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jdbc</artifactId>
    </dependency>

    <!-- MyBatis-Plus Spring Boot 3 starter -->
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-spring-boot3-starter</artifactId>
        <version>${mybatis-plus.version}</version>
    </dependency>

    <!-- 数据库驱动(示例用 MySQL) -->
    <dependency>
        <groupId>com.mysql</groupId>
        <artifactId>mysql-connector-j</artifactId>
        <scope>runtime</scope>
    </dependency>

    <!-- 可选:Lombok (简化实体) -->
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>

    <!-- 测试 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

注:使用 mybatis-plus-spring-boot3-starter 是推荐方式,官方/中央仓库有发布包可用。

3. 配置文件 application.yml

示例(MySQL):

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/demo?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC
    username: root
    password: root
    driver-class-name: com.mysql.cj.jdbc.Driver

mybatis-plus:
  configuration:
    # 驼峰映射:数据库 user_name -> Java userName
    map-underscore-to-camel-case: true
  global-config:
    db-config:
      logic-delete-field: deleted     # 逻辑删除字段名(可选)
      logic-delete-value: 1
      logic-not-delete-value: 0
  # mapper xml 路径(若使用 xml)
  mapper-locations: classpath:/mapper/**/*.xml
  type-aliases-package: com.example.demo.entity

解释:

4. 实体、Mapper、Mapper XML(或注解)

4.1 数据库表(示例)

CREATE TABLE user (
  id BIGINT AUTO_INCREMENT PRIMARY KEY,
  username VARCHAR(100),
  email VARCHAR(200),
  age INT,
  version INT DEFAULT 0,
  deleted TINYINT DEFAULT 0,
  created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
  updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);

4.2 实体类 User.java

package com.example.demo.entity;

import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import java.time.LocalDateTime;

@Data
@TableName("user")
public class User {
    @TableId(type = IdType.AUTO)
    private Long id;

    private String username;
    private String email;
    private Integer age;

    @Version
    private Integer version; // 乐观锁字段,@Version 标注

    @TableLogic
    private Integer deleted; // 逻辑删除,0 未删除,1 已删除

    @TableField(fill = FieldFill.INSERT)
    private LocalDateTime createdAt;

    @TableField(fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updatedAt;
}

说明:

4.3 Mapper 接口 UserMapper.java

package com.example.demo.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.demo.entity.User;
import org.apache.ibatis.annotations.Mapper;

@Mapper
public interface UserMapper extends BaseMapper<User> {
    // BaseMapper 已经包含常见 CRUD 方法(insert, deleteById, updateById, selectById, selectList...)
    // 可扩展自定义方法
}

MyBatis-Plus 提供 BaseMapper<T>,大幅减少重复 DAO 代码。

5. Service + Controller 快速 CRUD 示例

5.1 Service(直接使用 MP 的 Service 接口)

如果你喜欢 Service 层抽象,可以使用 MyBatis-Plus 的 IService 与 ServiceImpl:

package com.example.demo.service;

import com.baomidou.mybatisplus.extension.service.IService;
import com.example.demo.entity.User;

public interface IUserService extends IService<User> {
    // 自定义业务方法可以在这里扩展
}

实现类:

package com.example.demo.service.impl;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.example.demo.entity.User;
import com.example.demo.mapper.UserMapper;
import com.example.demo.service.IUserService;
import org.springframework.stereotype.Service;

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IUserService {
    // 使用内置的 save/update/getById/list 等方法
}

5.2 Controller 示例

package com.example.demo.controller;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.example.demo.entity.User;
import com.example.demo.service.IUserService;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import java.util.List;

@RestController
@RequestMapping("/users")
public class UserController {
    @Resource
    private IUserService userService;

    @GetMapping("/{id}")
    public User get(@PathVariable Long id) {
        return userService.getById(id);
    }

    @GetMapping
    public Page<User> list(@RequestParam(defaultValue = "1") long page,
                           @RequestParam(defaultValue = "10") long size,
                           @RequestParam(required = false) String name) {
        Page<User> p = new Page<>(page, size);
        LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
        if (name != null && !name.isEmpty()) {
            wrapper.like(User::getUsername, name);
        }
        return userService.page(p, wrapper);
    }

    @PostMapping
    public boolean create(@RequestBody User user) {
        return userService.save(user);
    }

    @PutMapping("/{id}")
    public boolean update(@PathVariable Long id, @RequestBody User user) {
        user.setId(id);
        return userService.updateById(user);
    }

    @DeleteMapping("/{id}")
    public boolean delete(@PathVariable Long id) {
        // 若启用了逻辑删除,则会被标记为已删除
        return userService.removeById(id);
    }
}

说明:

6. 分页与条件构造器重点说明

LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
wrapper.ge(User::getAge, 18)
       .le(User::getAge, 40)
       .like(User::getUsername, "张");

7. 常见插件配置(分页 / 乐观锁 / 逻辑删除 / 自动填充)

在 Spring Boot 的配置类中注册插件。

package com.example.demo.config;

import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MybatisPlusConfig {

    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        // 分页(针对 MySQL)
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor());
        // 乐观锁
        interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
        // 其他插件(如防止全表更新等)可在此追加
        return interceptor;
    }
}

说明要点:

8. 常见问题与调试技巧

1. SQL 不打印?

logging:
  level:
    com.baomidou.mybatisplus: debug
    org.mybatis: debug
    com.example.demo: debug

或使用 mybatis-plus.configuration.log-impl 指定 Slf4jImpl(部分版本需要)。查看日志可以帮助定位 SQL 与参数

2. 分页不起作用

3. 乐观锁失败却无异常

4. 逻辑删除仍能被查询到

5. Mapper XML 与 注解 混用

9. 小结(为什么选 MyBatis-Plus)

10. 参考 & 延伸阅读

到此这篇关于Spring Boot 3.0 + MyBatis-Plus全家桶实战的文章就介绍到这了,更多相关Spring Boot 3.0+MyBatis-Plus全家桶内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文