springboot集成mybaits plus实现增删改查功能(示例代码)

 更新时间:2026年04月18日 14:24:34   作者:爱意随风起^  
本文介绍了使用SpringBoot集成MyBatisPlus实现增删改查的全过程,包括添加依赖、配置数据库、创建表及实体类、Mapper和Service层的创建及实现等,最后通过knife4j或generated-requests.http进行测试,感兴趣的朋友跟随小编一起看看吧

1.引入依赖 

        <!--mybaits plus -->
        <!-- Source: https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-boot-starter -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-spring-boot4-starter</artifactId>
            <version>3.5.15</version>
        </dependency>
        <!--mysql8 -->
        <!-- Source: https://mvnrepository.com/artifact/com.mysql/mysql-connector-j -->
        <dependency>
            <groupId>com.mysql</groupId>
            <artifactId>mysql-connector-j</artifactId>
            <version>9.6.0</version>
            <scope>compile</scope>
        </dependency>
        <!-- druid -->
        <!-- Source: https://mvnrepository.com/artifact/com.alibaba/druid-spring-boot-starter -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.2.28</version>
            <scope>compile</scope>
        </dependency>
        <!-- lombok 简化代码,加上后不用写get,set方法 -->
        <!-- Source: https://mvnrepository.com/artifact/org.projectlombok/lombok -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.44</version>
            <scope>compile</scope>
        </dependency>

2.配置数据库

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/mybatisplus?serverTimezone=GMT%2B8
    username: root
    password: root
    type: com.alibaba.druid.pool.DruidDataSource
    druid:
      initial-size: 5
      min-idle: 10
      max-active: 20
      max-wait: 60000
      validation-query: SELECT 1
      test-on-borrow: true
      test-while-idle: true
      test-on-return: false

3.配置启动类

(加@MapperScan("路径要从com到mapper"))

4.创建表

CREATE TABLE `user_base` (
                             `id` bigint NOT NULL AUTO_INCREMENT COMMENT '用户ID',
                             `username` varchar(50) NOT NULL COMMENT '登录名',
                             `password` varchar(255) NOT NULL COMMENT '加密密码',
                             `phone` varchar(20) DEFAULT NULL COMMENT '手机号',
                             `email` varchar(100) DEFAULT NULL COMMENT '邮箱',
                             `real_name` varchar(50) DEFAULT NULL COMMENT '真实姓名',
                             `avatar` varchar(255) DEFAULT NULL COMMENT '头像URL',
                             `role_type` varchar(20) DEFAULT NULL COMMENT '冗余角色类型(平台管理员platform_admin、企业管理员enterprise_admin、个体户individual、消费者consumer、游客guest)',
                             `status` tinyint DEFAULT '1' COMMENT '状态:0禁用,1启用',
                             `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '注册时间',
                             PRIMARY KEY (`id`),
                             UNIQUE KEY `uk_username` (`username`),
                             UNIQUE KEY `uk_phone` (`phone`),
                             UNIQUE KEY `uk_email` (`email`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='用户基本信息表';

5.创建表对应的实体类

package com.example.entity;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import java.time.LocalDateTime;
@Data //加了这个注解就不用写get set 方法
@TableName("user_base")  //指定此类对应数据库哪个表,如果名字一样可以不用写
@Schema(description = "用户基础信息实体类") //用于knife4j生成接口文档
public class User_base {
    @TableId(type = IdType.AUTO) //告诉mybatisplus这个字段是自增的
    private Long id; //主键ID
    @TableField("username")  //指定此类对应数据库哪个属性,如果名字一样可以不用写
    @Schema(description = "用户名")  //用于knife4j生成接口文档
    private String username;
    @Schema(description = "密码")  //用于knife4j生成接口文档
    private String password;
    @Schema(description = "手机号")
    private String phone;
    @Schema(description = "邮箱")
    private String email;
    @Schema(description = "真实姓名")
    private String real_name;
    @Schema(description = "头像地址")
    private String avatar;
    @Schema(description = "角色类型:平台管理员platform_admin、企业管理员enterprise_admin、个体户individual、消费者consumer、游客guest")
    private String role_type;
    @Schema(description = "状态:0禁用、1启用")
    private Integer status;
    @Schema(description = "创建时间")
    private LocalDateTime create_time;
}

6.创建mapper

package com.example.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.entity.User_base;
import org.springframework.stereotype.Service;
public interface User_baseMapper extends BaseMapper<User_base> {
}

7.创建User_baseService

package com.example.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.example.entity.User_base;
public interface User_baseService extends IService<User_base> {
}

8.创建User_baseServiceImpl

package com.example.service.impl;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.example.entity.User_base;
import com.example.mapper.User_baseMapper;
import com.example.service.User_baseService;
import org.springframework.stereotype.Service;
@Service  //增加这个注释,将类托管给spring容器管理,在controller中就可以引用这个类了
public class User_baseServiceImpl extends ServiceImpl<User_baseMapper, User_base> implements User_baseService {
}

9.创建User_baseController

package com.example.controller;
import com.example.common.Result;
import com.example.entity.User_base;
import com.example.service.User_baseService;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import jakarta.annotation.Resource;
import org.springframework.web.bind.annotation.*;
@Tag(name = "用户管理")   //用于knife4j生成接口文档
@RestController        //加了这个注解,使可以接收http请求
public class User_baseController {
    @Resource  //@Resource 让 Spring 自动为你创建并注入所需的对象实例。
    private User_baseService user_baseService;
    @Operation(summary = "新增用户") //用于knife4j生成接口文档
    @PostMapping("/user_base/add")
    public Result add(@RequestBody User_base user_base){
        user_baseService.save(user_base);
        return Result.success("新增成功");
    }
    @Operation(summary = "查询所有用户")  //用于knife4j生成接口文档
    @GetMapping("/user_base/list")
    public Result list(){
        return Result.success(user_baseService.list());
    }
    @Operation(summary = "更新用户")  //用于knife4j生成接口文档
    @PostMapping("/user_base/update")
    public Result update(@RequestBody User_base user_base){
        user_baseService.updateById(user_base);
        return Result.success(user_base.getId());
    }
    @Operation(summary = "删除用户")  //用于knife4j生成接口文档
    @PostMapping("/user_base/delete")
    public Result delete(@RequestParam Long id){ //@RequestParam 从URL查询参数或表单数据中提取值,并赋值给方法参数
        user_baseService.removeById(id);
        return Result.success("删除成功");
    }
}

10.测试

可以在knife4j中完成测试,也可以在generated-requests.http中完成测试

knife4j:

generated-requests.http:

### 创建新用户测试
POST http://localhost:8787/pet/user_base/add
Content-Type: application/json
{
  "username": "123",
  "password": "123",
  "phone": "13",
  "email": "adm",
  "real_name": "lq",
  "avatar": "https://example.com/avatar.jpg",
  "role_type": "platform_admin",
  "status": 1
}
<> 2026-04-17T153449.200.json
<> 2026-04-17T151544.200.json
<> 2026-04-17T151525.500.json
<> 2026-04-17T150244.200.json
###
GET http://localhost:8787/pet/user_base/list
<> 2026-04-17T153610.200.json
<> 2026-04-17T153525.200.json
<> 2026-04-17T151548.200.json
<> 2026-04-17T151419.200.json
###
POST http://localhost:8787/pet/user_base/update
Content-Type: application/json
{
  "id": 1,
  "username": "testuser",
  "password": "456789",
  "phone": "13800138000",
  "email": "test@example.com",
  "real_name": "张三",
  "avatar": "https://example.com/avatar.jpg",
  "role_type": "platform_admin",
  "status": 1
}
<> 2026-04-17T152758.200.json
<> 2026-04-17T152602.400.html
<> 2026-04-17T152532.400.html
###
POST http://localhost:8787/pet/user_base/delete?id=4
Content-Type: application/x-www-form-urlencoded
<> 2026-04-17T153540.200.json

11.整体文件夹

到此这篇关于springboot集成mybaits plus,实现增删改查的文章就介绍到这了,更多相关springboot mybaits plus增删改查内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解Java中两种分页遍历的使用姿势

    详解Java中两种分页遍历的使用姿势

    这篇文章主要介绍了详解Java中两种分页遍历的使用姿势,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • Spring过滤器中OncePerRequestFilter应用实现

    Spring过滤器中OncePerRequestFilter应用实现

    OncePerRequestFilter是Spring框架提供的一个过滤器基类,本文就来介绍一下Spring过滤器中OncePerRequestFilter应用实现,感兴趣的可以了解一下
    2024-12-12
  • java property配置文件管理工具框架过程详解

    java property配置文件管理工具框架过程详解

    这篇文章主要介绍了java property配置文件管理工具框架过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • Java源码解析HashMap简介

    Java源码解析HashMap简介

    今天小编就为大家分享一篇关于Java源码解析HashMap简介,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • JavaCV摄像头实战之实现口罩检测

    JavaCV摄像头实战之实现口罩检测

    这篇文章主要介绍了利用JavaCV实现口罩检测,功能是检测摄像头内的人是否带了口罩,把检测结果实时标注在预览窗口。感兴趣的可以试一试
    2022-01-01
  • 在eclipse中安装Scala环境的步骤详解

    在eclipse中安装Scala环境的步骤详解

    这篇文章主要介绍了在eclipse中安装Scala环境的步骤,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • 通过实例解析java8中的parallelStream

    通过实例解析java8中的parallelStream

    这篇文章主要介绍了通过实例解析java8中的parallelStream,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • java基于poi导出excel透视表代码实例

    java基于poi导出excel透视表代码实例

    这篇文章主要介绍了java基于poi导出excel透视表代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • JAVA mongodb 聚合几种查询方式详解

    JAVA mongodb 聚合几种查询方式详解

    这篇文章主要介绍了JAVA mongodb 聚合几种查询方式详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • Spring Security自定义身份认证的实现方法

    Spring Security自定义身份认证的实现方法

    这篇文章主要介绍了Spring Security自定义身份认证的实现方法,下面对Spring Security的这三种自定义身份认证进行详细讲解,需要的朋友可以参考下
    2025-04-04

最新评论