基于SpringBoot+Mybatis-Plus的快速入门案例

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 基于SpringBoot+Mybatis-Plus的快速入门案例——图书管理系统

基于SpringBoot+Mybatis-Plus的快速入门案例

图书管理系统 源码已上传Gitee 源码地址

参考视频 : 黑马程序员SpringBoot

1. 技术栈和环境配置

  • SpringBoot 2.6.7
  • Mybatis-Plus 3.4.3
  • Lombok 1.18
  • mysql 5.6
  • JDK 8

2.案例效果演示

  • 2.1添加书籍

image-20220515171305431

  • 2.2 删除书籍

image-20220515171335591

  • 2.3 修改书籍

image-20220515171400862

  • 2.4 按条件查询书籍

image-20220515171424577

  • 2.5分页

image-20220515171456800

3.案例分析

3.1实体类

使用Lombok快速制作实体类

@Data
//标注sql数据表名称
@TableName("t_book")
public class Books {

    private Integer id;
    private String type;
    private String name;
    private String description;
    
}

3.2数据层

整合MybatisPlus

application.yml文件

#端口号
server:
  port: 80

#数据源
spring:
  datasource:
    druid:
      driver-class-name: com.mysql.cj.jdbc.Driver
      url: jdbc:mysql://localhost:3306/db4?serverTimezone=UTC
      username: root
      password: 

#mybatis-plus 使用数据库自增算法
mybatis-plus:
  global-config:
    db-config:
      id-type: auto
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

#开启MP日志并设置输出方式为标准输出(输出控制台) 用于测试

配置MP的分页拦截器

@Configuration
public class MPConfig {
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor(){
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor());

        return interceptor;
    }

}

MySQL数据表——t_book

CREATE TABLE t_book(
id INT NOT NULL AUTO_INCREMENT,
TYPE VARCHAR(20),
NAME VARCHAR(20),
description VARCHAR(20),
PRIMARY KEY (id)
)ENGINE=INNODB  DEFAULT CHARSET=utf8;

3.3业务层/服务层

基于MyBatisPlus进行增量开发

IBookService接口类

注:此接口继承MybatisPlus提供的IService接口,默认实现了许多业务操作

public interface IBookService extends IService<Books> {

  boolean saveBook(Books books);

  boolean modify(Books books);

  boolean delete(Integer id);

  IPage<Books> getPage(int currentPage, int pageSize);

  IPage<Books> getPage(int currentPage, int pageSize,Books books);

}

BookServiceImpl实现类

注:此类继承ServiceImpl<BookDao,Books>类,参数为接口和实体类,代表映射关系

@Service
public class BookServiceImpl extends ServiceImpl<BookDao,Books> implements IBookService {

    @Autowired
    private BookDao bookDao;

    @Override
    public boolean saveBook(Books books) {
        return bookDao.insert(books) > 0;
    }

    @Override
    public boolean modify(Books books) {
        return bookDao.updateById(books) > 0;
    }

    @Override
    public boolean delete(Integer id) {
        return  bookDao.deleteById(id) > 0;
    }

    @Override
    public IPage<Books> getPage(int currentPage, int pageSize) {
       IPage page = new Page(currentPage,pageSize);

       bookDao.selectPage(page,null);
       return page;
    }

    @Override
    public IPage<Books> getPage(int currentPage, int pageSize, Books books) {
        LambdaQueryWrapper<Books> lqw = new LambdaQueryWrapper<>();
        lqw.like(Strings.isNotEmpty(books.getType()), Books::getType,books.getType());
        lqw.like(Strings.isNotEmpty(books.getName()), Books::getName,books.getName());
        lqw.like(Strings.isNotEmpty(books.getDescription()), Books::getDescription,books.getDescription());
        IPage page = new Page(currentPage,pageSize);

        bookDao.selectPage(page,lqw);
        return page;

    }
}

3.4表现层/控制层

基于Restful风格

BookController类

@RestController
@RequestMapping("/books")
public class BookController {

    @Autowired
    private IBookService bookService;

    @GetMapping
    public ResultMessage getAll() {
        return new ResultMessage(true,bookService.list());
    }

    @PostMapping
    public ResultMessage save(@RequestBody Books books) {
     return new ResultMessage(bookService.saveBook(books));

    }

    @DeleteMapping("{id}")
    public ResultMessage delete(@PathVariable Integer id) {
        return new ResultMessage(bookService.delete(id));
    }

    @PutMapping
    public ResultMessage update(@RequestBody Books books) {
        return  new ResultMessage(bookService.modify(books));
    }

    @GetMapping("{id}")
    public ResultMessage getById(@PathVariable Integer id) {
        //true表示查询到数据了 可能为空
        return new ResultMessage(true,bookService.getById(id));
    }

    /**
     * 分页  条件查询
     * @param currentPage
     * @param pageSize
     * @param books
     * @return
     */

    @GetMapping("{currentPage}/{pageSize}")
    public ResultMessage getPage(@PathVariable int currentPage, @PathVariable int pageSize, Books books) {
          IPage<Books> page = bookService.getPage(currentPage, pageSize,books);
          //解决删除某页唯一一条数据时,出现空页面的问题
          if (currentPage > page.getPages()){
              page = bookService.getPage((int) page.getPages(),pageSize,books);
          }
        return new ResultMessage(true, page);
    }

}

表现层消息一致性处理,前后端数据协议

ResultMessage类,消息统一处理

@Data
public class ResultMessage {

    private Boolean flag;
    private Object data;

    private String message;

    public ResultMessage(){

    }
    public ResultMessage(Boolean flag){
        this.flag = flag;
    }

    public ResultMessage(Boolean flag, Object data){
        this.flag = flag;
        this.data = data;
    }


    public ResultMessage(String message){
        this.flag = flag;
        this.message = message;
    }

    public ResultMessage(Boolean flag, String message){
        this.flag = flag;
        this.message = message;
    }
}

异常处理

@RestControllerAdvice
public class ExceptionAdvice {

    //拦截异常
    @ExceptionHandler
    public ResultMessage doException(Exception e){
        e.printStackTrace();
        return new ResultMessage("服务器故障,稍后再试");
    }

}

3.5页面开发

基于VUE+ElementUI

页面数据处理、页面消息处理

books.html (部分代码)

<script>
    var vue = new Vue({
        el: '#app',
        data: {
            dataList: [],//当前页要展示的列表数据
            dialogFormVisible: false,//添加表单是否可见
            dialogFormVisible4Edit: false,//编辑表单是否可见
            formData: {},//表单数据
            rules: {//校验规则
                type: [{required: true, message: '图书类别为必填项', trigger: 'blur'}],
                name: [{required: true, message: '图书名称为必填项', trigger: 'blur'}]
            },
            pagination: {   //分页相关模型数据
                currentPage: 1,   //当前页码
                pageSize: 10,   //每页显示的记录数
                total: 0,  //总记录数
                type:"",
                name:"",
                description:""
            }
        },

        //钩子函数,VUE对象初始化完成后自动执行
        created() {
            this.getAll();
        }
         }) 
   </script>
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
27天前
|
缓存 Java 数据库连接
深入探讨:Spring与MyBatis中的连接池与缓存机制
Spring 与 MyBatis 提供了强大的连接池和缓存机制,通过合理配置和使用这些机制,可以显著提升应用的性能和可扩展性。连接池通过复用数据库连接减少了连接创建和销毁的开销,而 MyBatis 的一级缓存和二级缓存则通过缓存查询结果减少了数据库访问次数。在实际应用中,结合具体的业务需求和系统架构,优化连接池和缓存的配置,是提升系统性能的重要手段。
44 4
|
27天前
|
SQL Java 数据库连接
spring和Mybatis的各种查询
Spring 和 MyBatis 的结合使得数据访问层的开发变得更加简洁和高效。通过以上各种查询操作的详细讲解,我们可以看到 MyBatis 在处理简单查询、条件查询、分页查询、联合查询和动态 SQL 查询方面的强大功能。熟练掌握这些操作,可以极大提升开发效率和代码质量。
43 3
|
1月前
|
Java 数据库连接 数据库
spring和Mybatis的逆向工程
通过本文的介绍,我们了解了如何使用Spring和MyBatis进行逆向工程,包括环境配置、MyBatis Generator配置、Spring和MyBatis整合以及业务逻辑的编写。逆向工程极大地提高了开发效率,减少了重复劳动,保证了代码的一致性和可维护性。希望这篇文章能帮助你在项目中高效地使用Spring和MyBatis。
26 1
|
2月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
151 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
2月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
81 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
1月前
|
消息中间件 NoSQL Java
springboot整合常用中间件框架案例
该项目是Spring Boot集成整合案例,涵盖多种中间件的使用示例,每个案例项目使用最小依赖,便于直接应用到自己的项目中。包括MyBatis、Redis、MongoDB、MQ、ES等的整合示例。
114 1
|
1月前
|
SQL Java 数据库连接
MyBatis-Plus快速入门:从安装到第一个Demo
本文将带你从零开始,快速入门 MyBatis-Plus。我们将首先介绍如何安装和配置 MyBatis-Plus,然后通过一个简单的示例演示如何使用它进行数据操作。无论你是 MyBatis 的新手还是希望提升开发效率的老手,本文都将为你提供清晰的指导和实用的技巧。
465 0
MyBatis-Plus快速入门:从安装到第一个Demo
|
2月前
|
缓存 Java 数据库连接
使用MyBatis缓存的简单案例
MyBatis 是一种流行的持久层框架,支持自定义 SQL 执行、映射及复杂查询。本文介绍了如何在 Spring Boot 项目中集成 MyBatis 并实现一级和二级缓存,以提高查询性能,减少数据库访问。通过具体的电商系统案例,详细讲解了项目搭建、缓存配置、实体类创建、Mapper 编写、Service 层实现及缓存测试等步骤。
|
2月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
275 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库