SpringBoot集成MyBatisPlus+MySQL(超详细)
创始人
2025-01-15 07:33:56
0

在这里插入图片描述
😊 @ 作者: Eric
💖 @ 主页: https://blog.csdn.net/weixin_47316183?type=blog
🎉 @ 主题:SpringBoot集成MyBatisPlus+MySQL(超详细)
⏱️ @ 创作时间: 2023年08月06日

在这里插入图片描述

文章目录

  • 1、什么是MyBatisPlus
  • 2、SpringBoor整合MyBatisPlus
    • 2.1、配置
    • 2.2、使用MyBatisPlus
    • 2.3、效果
  • 总结


1、什么是MyBatisPlus

MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

MybatisPlus可以节省大量时间,所有的CRUD代码都可以自动化完成

特性

  1. 无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑
  2. 损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作
  3. 强大的 CRUD 操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求
  4. 支持 Lambda 形式调用:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错
  5. 支持主键自动生成:支持多达 4 种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解决主键问题
  6. 支持 ActiveRecord 模式:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操作
  7. 支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere )
  8. 内置代码生成器:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用
  9. 内置分页插件:基于 MyBatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通 List 查询
  10. 分页插件支持多种数据库:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库
  11. 内置性能分析插件:可输出 SQL 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询
  12. 内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作

MyBatisPlus官方网站:https://baomidou.com/

2、SpringBoor整合MyBatisPlus

2.1、配置

1、先准备好数据库环境

CREATE DATABASE mybatisplus;  USE mybatisplus;  CREATE TABLE eric_user( `id` INT AUTO_INCREMENT, `name` VARCHAR(255) COMMENT '名称', PRIMARY KEY (`id`) );  INNER INTO eric_user(`name`) VALUES('Eric'),('blue');  INSERT  INTO `eric_user`(`id`,`name`) VALUES  (1,'Eric'), (2,'Jack'), (3,'Lucy'); 

2、创建一个SpringBoot项目
在这里插入图片描述


3、引入MyBatisPlus相关依赖(因为要操作数据库,所以这里也引入了MySQL依赖)

      com.baomidou     mybatis-plus-boot-starter     3.3.1         mysql     mysql-connector-java         org.projectlombok     lombok  

4、修改配置文件

server:   port: 8080  spring:   datasource:     driver-class-name: com.mysql.cj.jdbc.Driver     url: jdbc:mysql://localhost:3306/mybatisplus?serverTimezone=GMT%2B8     username: root     password: root   #开启日志 mybatis-plus:   configuration:     log-impl: org.apache.ibatis.logging.stdout.StdOutImpl   


2.2、使用MyBatisPlus

1、创建一个实体类

package com.eric.springbootmybatisplus.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 lombok.Data;  /**  * @author Eric  * @date 2023-08-01 15:38  */ @Data @TableName(value = "eric_user") public class EricUser {      @TableId(value = "id", type = IdType.AUTO)     private Integer id;      @TableField(value = "name")     private String name;  }   

2、Mapper层

package com.eric.springbootmybatisplus.mapper;  import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.eric.springbootmybatisplus.entity.EricUser; import org.apache.ibatis.annotations.Mapper;  /**  * @author Eric  * @date 2023-08-01 15:39  */ @Mapper public interface EricUserMapper extends BaseMapper { }  

3、service层

package com.eric.springbootmybatisplus.service;  import com.baomidou.mybatisplus.extension.service.IService; import com.eric.springbootmybatisplus.entity.EricUser;  /**  * @author Eric  * @date 2023-08-01 15:40  */ public interface EricUserService extends IService { }  

impl

package com.eric.springbootmybatisplus.service.impl;  import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.eric.springbootmybatisplus.entity.EricUser; import com.eric.springbootmybatisplus.mapper.EricUserMapper; import com.eric.springbootmybatisplus.service.EricUserService; import org.springframework.stereotype.Service;  /**  * @author Eric  * @date 2023-08-01 15:42  */ @Service public class EricUserServiceImpl extends ServiceImpl implements EricUserService { }  

4、controller

package com.eric.springbootmybatisplus.controller;  import com.eric.springbootmybatisplus.entity.EricUser; import com.eric.springbootmybatisplus.service.EricUserService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;  import java.util.List;  /**  * @author Eric  * @date 2023-08-01 15:43  */ @RestController @RequestMapping("/eric") public class EricUserController {     @Autowired     private EricUserService userService;      @GetMapping("")     public List getEricUserList(){         List list = userService.list();         return list;     } }  

2.3、效果

此时运行项目,访问 IP+端口/接口地址
例如:http://127.0.0.1:8080/eric


结果如下
在这里插入图片描述


总结

怎么样,是不是特别的方便和简单~

相关内容

热门资讯

XML Schema 杂项数据... XML Schema 杂项数据类型XML Schema 提供了多种数据类型,用于定义 XML 文档中...
Html5前端基本知识整理与回... 今天我们继续结合发布的Html5基础知识点文档进行复习,希望对大家有所帮助。目录列表无...
数据结构练习 1.快速排序的非递归是通过栈来实现的,则前序与层次可以通过控制入栈的顺序来实现...
AJAX学习笔记上(学习自用) AJAX原生AJAX1.1AJAX简介AJAX全程为Asynchronous JavaScript ...
React 开发报错整理 1、'yield' expression implicitly results in an 'any...
LLaMA 模型 大模型LLaMA详解LLaMa系列模型详解(原理介绍、代码解读)...
LlamaFactory可视化... LlamaFactory 前言LLaMA Factory 是一个用于微调大型语言模型的强大工具,特别...
Ajax从零到实战   💝💝💝欢迎来到我的博客,很高兴能够...
基于泰坦尼克号生还数据进行 S... 基于泰坦尼克号生还数据进行 Spark 分析在这篇博客中,我们将展示如何使用 Apac...
在亚马逊云科技AWS上利用Sa... 项目简介:接下来,小李哥将会每天介绍一个基于亚马逊云科技AWS云计算平台...