Spring Boot整合Mybatis Plus[极简教程]

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Spring Boot整合Mybatis Plus[极简教程]

一、简单介绍

Mybatis Plus,简称MP,官网https://mp.baomidou.com/

在MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

意愿:成为 MyBatis 最好的搭档,就像 魂斗罗 中的 1P、2P,基友搭配,效率翻倍。

二、环境准备和基本配置

1.创建Spring Boot项目,引入依赖
<!--mysql驱动-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.47</version>
        </dependency>
        <!-- 整合mybatis plus-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.2.0</version>
        </dependency>
        <!-- 数据库连接池-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.9</version>
        </dependency>
        <!--  test依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
2.修改配置文件
server:
  port: 8099
spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    username: root
    password: 12345
    url: jdbc:mysql://127.0.0.1:3306/test
    type: com.alibaba.druid.pool.DruidDataSource
3.数据库准备
CREATE TABLE `student` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
4.项目结构和实体类准备

实体类:

public class Student {
    private Integer id;
    private String name;
    private Integer age;
    //构造方法......
    //Getter、Setter......
}

三、CRUD操作

1.继承BaseMapper

首先将Mapper层的接口集成BaseMapper,其中T就是需要操作的实体类泛型

@Mapper
@Repository
public interface StudentMapper extends BaseMapper<Student> {
}
2.创建Service层接口和实现类

接口

public interface StudentService {
    /**
     * 保存Student
     *
     * @param student
     * @return
     */
    int saveStudent(Student student);
    /**
     * 根据id查找
     *
     * @param id
     * @return
     */
    Student findStudentById(int id);
    /**
     * 查找全部
     *
     * @return
     */
    List<Student> fingAllStudnet();
    /**
     * 删除一个
     *
     * @param id
     * @return
     */
    int deleteStudentById(int id);
    /**
     * 修改一个
     *
     * @param student
     * @return
     */
    int updateStudentById(Student student);
    /**
     * 根据姓模糊查询
     *
     * @param firstName
     * @return
     */
    List<Student> findStudentByFirstName(Student firstName);
}

实现类

@Service
public class StudentServiceImpl implements StudentService {
    @Autowired
    private StudentMapper studentMapper;
    @Override
    public int saveStudent(Student student) {
        return 0;
    }
    @Override
    public Student findStudentById(int id) {
        return null;
    }
    @Override
    public List<Student> findAllStudent() {
        return null;
    }
    @Override
    public int deleteStudentById(int id) {
        return 0;
    }
    @Override
    public int updateStudentById(Student student) {
        return 0;
    }
    @Override
    public List<Student> findStudentByFirstName(String firstName) {
        return null;
    }
}
3.方法的实现

下面我们来一一的实现这些方法

(1)保存一个
@Override
public int saveStudent(Student student) {
    return studentMapper.insert(student);
}

测试:

@Autowired
private StudentService studentService;
@Test
void testSaveStudent() {
    Student student = new Student(1,"张三", 23);
    System.out.println(studentService.saveStudent(student));
}

结果:

(2)根据id查找
@Override
public Student findStudentById(int id) {
    QueryWrapper<Student> wrapper = new QueryWrapper<>();
    wrapper.eq("id", id);
    return studentMapper.selectOne(wrapper);
}

测试

@Test
void testFindStuById() {
    System.out.println(studentService.findStudentById(1));
}

结果:

(3)查找全部

在查找全部之前我们先多插入一点

@Override
public List<Student> findAllStudent() {
    return studentMapper.selectList(new QueryWrapper<>());
}

测试

@Test
void testFindAllStu(){
    System.out.println(studentService.findAllStudent());
}

结果:

(4)删除一个
@Override
public int deleteStudentById(int id) {
    return studentMapper.deleteById(id);
}

测试

@Test
void testRemoveStudent(){
    System.out.println(studentService.deleteStudentById(1));
}

结果

(5)修改一个
@Override
public int updateStudentById(Student student) {
    return studentMapper.updateById(student);
}

测试

@Test
void testUpdateStu(){
    System.out.println(studentService.updateStudentById(new Student(2,"张小四",200)));
}

结果

(6)根据姓模糊查询

找出全部姓张的人

@Override
public List<Student> findStudentByFirstName(String firstName) {
    QueryWrapper<Student> wrapper = new QueryWrapper<>();
    wrapper.likeRight("name", firstName);
    return studentMapper.selectList(wrapper);
}

测试

@Test
void testLikeFind(){
    System.out.println(studentService.findStudentByFirstName("张"));
}

结果

四、可能遇到的问题

1.让主键自增
@TableId(type = IdType.AUTO)
private Integer id;
2.实体类和表名不一致
//@TableName("数据库表名")
@TableName("student")
3.实体类属性和表的字段名不一致
@TableId(value = "id", type = IdType.AUTO)
private Integer id;
@TableField("name")
private String name;
@TableField("age")
private Integer age;
4.插入数据后让自增id回写(很实用)
@TableId(value = "id", type = IdType.AUTO)  //只能有一个@TableId
private Integer id;
@TableField("name")
private String name;
@TableField("age")
private Integer age;

测试下:

// Service
@Override
public int saveStudent(Student student) {
    int result = studentMapper.insert(student);
    System.out.println(student);
    return result;
}
//  Test  //
@Test
void testSaveStudent() {
    Student student = new Student( "张四", 23);
    System.out.println(studentService.saveStudent(student));
}


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3天前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
12天前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
1月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
105 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
1月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
52 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
19天前
|
SQL 存储 数据库
深入理解@TableField注解的使用-MybatisPlus教程
`@TableField`注解在MyBatis-Plus中是一个非常灵活和强大的工具,能够帮助开发者精细控制实体类与数据库表字段之间的映射关系。通过合理使用 `@TableField`注解,可以实现字段名称映射、自动填充、条件查询以及自定义类型处理等高级功能。这些功能在实际开发中,可以显著提高代码的可读性和维护性。如果需要进一步优化和管理你的MyBatis-Plus应用程
92 3
|
23天前
|
JSON Java Maven
实现Java Spring Boot FCM推送教程
本指南介绍了如何在Spring Boot项目中集成Firebase云消息服务(FCM),包括创建项目、添加依赖、配置服务账户密钥、编写推送服务类以及发送消息等步骤,帮助开发者快速实现推送通知功能。
61 2
|
1月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
64 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
1月前
|
SQL Java 数据库连接
mybatis使用二:springboot 整合 mybatis,创建开发环境
这篇文章介绍了如何在SpringBoot项目中整合Mybatis和MybatisGenerator,包括添加依赖、配置数据源、修改启动主类、编写Java代码,以及使用Postman进行接口测试。
16 0
mybatis使用二:springboot 整合 mybatis,创建开发环境
|
1月前
|
Java 数据库连接 API
springBoot:后端解决跨域&Mybatis-Plus&SwaggerUI&代码生成器 (四)
本文介绍了后端解决跨域问题的方法及Mybatis-Plus的配置与使用。首先通过创建`CorsConfig`类并设置相关参数来实现跨域请求处理。接着,详细描述了如何引入Mybatis-Plus插件,包括配置`MybatisPlusConfig`类、定义Mapper接口以及Service层。此外,还展示了如何配置分页查询功能,并引入SwaggerUI进行API文档生成。最后,提供了代码生成器的配置示例,帮助快速生成项目所需的基础代码。
|
1月前
|
Java 数据库连接 Maven
Spring整合Mybatis
Spring整合Mybatis