Spring Boot + Mybtis-plus集成

news2025/1/17 1:19:28

目录

  • 需求分析
  • Maven 相关依赖
  • 配置文件
  • 相关流程
    • MybatisPlus配置
    • 自动补全参数配置
    • 逻辑删除注解
    • 乐观锁注解


需求分析

Spring Boot和MyBatis-Plus是目前使用最广泛的Java web开发框架和ORM框架,它们可以很好地协同工作,提供高效和稳定的系统开发和数据操作。以下是对Spring Boot + MyBatis-Plus集成需求分析的一个概述

  1. 配置文件:
    首先需要在Spring Boot的启动文件中,配置MyBatis-Plus相关的配置,以及数据库连接信息、驱动等。MyBatis-Plus在Spring Boot的启动文件中可以通过注解或者XML文件进行配置。
  2. 定义实体类:
    需要定义Java实体类,其字段对应数据库表的字段。可以使用注解的方式定义类和字段与数据库表和字段的对应关系。
  3. 定义Mapper类和XML文件:
    使用MyBatis-Plus的Mapper类,定义DAO层的CRUD操作。可以使用MyBatis-Plus提供的通用Mapper类,简化Mapper类的开发。同时,需要定义Mapper类对应的XML文件,与Mapper类一一对应和映射。
  4. 配置分页和缓存:
    需要对分页和缓存进行配置。可以使用MyBatis-Plus提供的分页插件和缓存插件,对分页和缓存进行管理和优化。
  5. 配置事务:

在操作数据库时需要开启事务支持,以保证数据的完整性和一致性。可以在Spring Boot的启动文件中配置事务管理器,操作DAO层的每个方法都会被包裹在一个事务中,以保证事务的一致性。

通过对以上需求的分析和处理,可以高效、快速地开发出高质量和可靠性的系统。同时,MyBatis-Plus可以提供ORM框架的中间件的支持,简化了数据操作和管理的复杂性。

Maven 相关依赖

主要引入了如下依赖:

  1. mybatis-plus-boot-starter依赖
  2. mybatis-plus-generator依赖
  3. freemarker依赖
  4. mysql-connector-java依赖
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.freemarker</groupId>
            <artifactId>freemarker</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>

配置文件

主要配置如下:

  1. 配置mybatisplus日志
  2. 配置数据库
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.slf4j.Slf4jImpl #mybatis日志配置
spring:
  datasource: #配置数据库
    dynamic:
      primary: master #设置默认的数据源或者数据源组,默认值即为master
      strict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源
      datasource:
        master:
          driver-class-name: com.mysql.cj.jdbc.Driver
          url: jdbc:mysql://127.0.0.1:3306/数据库名称?useUnicode=true&useSSL=false&characterEncoding=utf8&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true&autoReconnect=true&failOverReadOnly=false
          username: root
          password: 123456

相关流程

MybatisPlus配置

主要做了如下操作:

  1. 通过@MapperScan注解声明扫描路径
  2. 注入自定义配置Bean
    1. 添加租户配置
      1. 重写获取租户方法
      2. 重写忽略租户方法
    2. 分页插件配置
    3. 数据库类型配置
    4. 分页溢出处理
    5. 乐观锁
@Configuration
@MapperScan("com.llfy.saapp.page.*.mapper")
public class MybatisPlusConfig {

    /**
     * MybatisPlus配置
     * @return MybatisPlusInterceptor
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new TenantLineInnerInterceptor(new TenantLineHandler() {
            @Override
            public Expression getTenantId() {
                return new StringValue(Objects.requireNonNull(SecurityContextUtils.getTenantId()));
            }

            @Override
            public boolean ignoreTable(String tableName) {
                return Arrays.stream(IgnoreTableList.getIgnoreTableList())
                        .collect(Collectors.toList()).contains(tableName);
            }
        }));
        //分页插件
        PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
        //数据库类型
        paginationInnerInterceptor.setDbType(DbType.MYSQL);
        //分页溢出处理
        paginationInnerInterceptor.setOverflow(true);
        interceptor.addInnerInterceptor(paginationInnerInterceptor);
        //乐观锁
        interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
        return interceptor;
    }

}

自动补全参数配置

主要做了如下操作:

  1. 实现MetaObjectHandler()接口
  2. 声明常量
  3. 实现新增:触发的方法insertFill,该方法通过参数上的注解@TableField(fill = FieldFill.INSERT)触发
    1. 新增数据时回填创建时间为当前时间
    2. 新增时回填创建人为当前上下文中的用户
  4. 实现修改:触发方法updateFill,该方法通过参数上的注解@TableField(fill = FieldFill.INSERT_UPDATE)触发
    1. 修改数据时回填修改时间为当前时间
    2. 修改时回填修改人为当前上下文中的用户
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {

    private static final String CREATE_TIME = "createTime";
    private static final String CREATE_USER = "createUser";
    private static final String UPDATE_TIME = "updateTime";
    private static final String UPDATE_USER = "updateUser";
    private static final String DELETE_TIME = "deleteTime";
    private static final String DELETE_USER = "deleteUser";
    private static final String IS_DELETE = "isDelete";

    public static final String IS_EXPIRED = "isExpired";

    public static final String IS_LOCKED = "isLocked";

    public static final String IS_CREDENTIALS_EXPIRED = "isCredentialsExpired";

    public static final String IS_DISABLE = "isDisable";

    public static final String EXPIRED_TIME = "expiredTime";

    public static final String LOCKED_TIME = "lockedTime";

    public static final String CREDENTIALS_EXPIRED_TIME = "credentialsExpiredTime";

    public static final String DISABLE_TIME = "disableTime";

    @Override
    public void insertFill(MetaObject metaObject) {
        this.strictInsertFill(metaObject, CREATE_TIME, Date.class, new Date());
        this.strictInsertFill(
                metaObject,
                CREATE_USER,
                String.class,
                SecurityContextUtils.getUserId());
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        this.strictUpdateFill(metaObject, UPDATE_TIME, Date.class, new Date());
        this.strictUpdateFill(
                metaObject,
                UPDATE_USER,
                String.class,
                SecurityContextUtils.getUserId());
        String gson = new Gson().toJson(metaObject.getOriginalObject());
        JSONObject jsonObject = JSONObject.parseObject(gson);
        //删除状态变更
        if (jsonObject.containsKey(IS_DELETE) && jsonObject.getBoolean(IS_DELETE)) {
            this.strictUpdateFill(metaObject, DELETE_TIME, Date.class, new Date());
            this.strictUpdateFill(
                    metaObject,
                    DELETE_USER,
                    String.class,
                    SecurityContextUtils.getUserId());
        }
        //用户过期状态变更
        if (jsonObject.containsKey(IS_EXPIRED) && jsonObject.getBoolean(IS_EXPIRED)) {
            this.strictUpdateFill(metaObject, EXPIRED_TIME, Date.class, new Date());
        }
        //用户锁定状态变更
        if (jsonObject.containsKey(IS_LOCKED) && jsonObject.getBoolean(IS_LOCKED)) {
            this.strictUpdateFill(metaObject, LOCKED_TIME, Date.class, new Date());
        }
        //用户凭证过期状态变更
        if (jsonObject.containsKey(IS_CREDENTIALS_EXPIRED)
                && jsonObject.getBoolean(IS_CREDENTIALS_EXPIRED)) {
            this.strictUpdateFill(metaObject, CREDENTIALS_EXPIRED_TIME, Date.class, new Date());
        }
        //用户禁用状态变更
        if (jsonObject.containsKey(IS_DISABLE) && jsonObject.getBoolean(IS_DISABLE)) {
            this.strictUpdateFill(metaObject, DISABLE_TIME, Date.class, new Date());
        }
    }
}

逻辑删除注解

逻辑删除:在实体使用注解@TableLogic中标注字段,例如

public class MenuInfo extends Model<MenuInfo> {
    @ApiModelProperty(value = "删除状态 0-不删除 1-删除")
    @TableLogic
    private Boolean isDelete;
}

乐观锁注解

逻辑删除:在实体使用注解@Version中标注字段,例如

public class MenuInfo extends Model<MenuInfo> {
    @ApiModelProperty(value = "乐观锁")
    @Version
    private Integer version;
}

关于mybatis详细的使用方法请转至Mybatis-Plus官网阅读


在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/550792.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[答疑]UML精粹里和你视频里说的不太一样

DDD领域驱动设计批评文集>> 《软件方法》强化自测题集>> 《软件方法》各章合集>> 第五元素 2023-4-14 20:32 这是是UML精粹里的。潘老师&#xff0c;这个跟你视频里讲的是不是不太一样&#xff1f;还是我理解错了&#xff1f; UMLChina潘加宇 这个&#…

软件最后一步------打包

本文章主要是记将源代码打包成程序 Python 一、安装Pyinstaller (用于打包的库) pip install pyinstaller二、使用参数 参数介绍 选项参数参数解释-hhelp(帮助信息)-vversion(版本号)-c显示命令行窗口-w不显示命令行窗口-F生成结果是一个exe程序&#xff0c;所有依赖项被打…

计算机的基本工作原理

参考资料&#xff1a; L-1.6: Common Bus system| How basic computer works - YouTube 准备好内存单元、不同类型的寄存器&#xff0c;内存和寄存器、寄存器和寄存器之间都是通过总线连接(假设是直接把数据总线、控制总线、地址总线变成一条总线)。 使用多路复用器实现的总线&…

C语言—通讯录

通讯录 通讯录的创建通讯录的初始化通讯录添加联系人信息通讯录删除特定联系人信息通讯录查找特定联系人信息通讯录修改特定联系人信息通讯录排序联系人信息通讯录打印联系人信息通讯录整体代码 通讯录的创建 通讯录中是存放人的信息的&#xff0c;人的信息包括&#xff1a;姓…

数据结构—排序算法交换排序(冒泡快排)

目录 1.交换排序—冒泡排序 1.1冒泡排序基本思想 1.2冒泡排序的实现 2.交换排序—快速排序 1.1快速排序基本思想 1.2基准值划分—分析 1. hoare版&#xff1a; 2. 挖坑法&#xff1a; 3. 前后指针版本 1.3 hoare快排的具体实现 1.4 挖坑法快排的具体实现 1.5 前后指…

【Stable Diffusion WebUI】一篇文章教你如何安装和使用Stable Diffusion WebUI

文章目录 Stable Diffusion WebUI1. 安装1.1 下载 stable-diffusion-webui1.2 运行 webui.sh 2. 安装插件2.1 命令行安装2.2 extensions 安装2.3 常用插件 3. 使用教程3.1 页面布局3.3 快捷栏设置3.3.1 PNG Info3.3.2 Tagger Stable Diffusion WebUI 1. 安装 1.1 下载 stable…

Python中的集合介绍

集合set是一个无序的、不可重复的元素集合。 集合的创建 大括号 {} set() a {1, 2, 3, 4, 5} print(type(a))b set([1,2,3,4,5,6,7]) print(type(b),b)c set((1,2,3)) print(c) 运行结果&#xff1a;<class set> <class set> {1, 2, 3, 4, 5, 6, 7} {1, 2, 3} 集…

诺贝尔化学奖:酶分子“定向进化”

2018年&#xff0c;诺贝尔化学奖迎来了历史上第五位女性得主——加州理工学院的Frances H. Arnold教授&#xff0c;以表彰她在“酶的定向进化”这一领域的贡献。 1、“酶的定向进化”到底是什么&#xff1f; 这里有三个点&#xff0c;“酶”、“进化”还有“定向”&#xff1a…

windows10安装Qt

一、下载安装包 1、安装包下载路径调整 由于Qt公司的调整&#xff0c;从5.15版本开始原本下载的路径不再提供安装包 Index of /archive/qt 新安装包放在了official_releases里面了 Index of /official_releases/online_installers 2、安装方式调整 从5.9.0开始安装方式开始…

streamlit应用部署和streamcloud发布APP

文章目录 streamlit应用创建streamcloud创建APP注册streamcloud账号设置StreamLit许可发布APPstreamlit应用创建 streamcloud创建APP StreamCloud是一个用于部署StreamLit App 的平台。 注册streamcloud账号 点击https://share.streamlit.io/ ,进入StreamCloud 注册界面。…

在四维轻云平台中如何使用场景搭建功能?

四维轻云是一款轻量化的地理空间数据管理云平台&#xff0c;能够实现多种地理空间数据的在线管理、编辑及分享。目前&#xff0c;平台具有项目管理、成员管理、场景搭建、在线分享、素材库等功能&#xff0c;支持多用户在线协作管理&#xff0c;实现了轻量化、便捷化的空间数据…

chatgpt赋能Python-pythonda

Python在SEO优化中的作用 简介 SEO&#xff08;Search Engine Optimization&#xff09;即搜索引擎优化&#xff0c;是指通过优化网站目标关键词的排名来提高网站的曝光率和流量。Python是一种高级编程语言&#xff0c;在SEO领域中有着广泛的应用。 Python在SEO中的应用 网…

AudioGPT推出!音频领域都不放过,ChatGPT这是杀疯了!

大家好&#xff0c;我是千与千寻&#xff0c;你们可以叫我千寻哥&#xff0c;算一算写ChatGPT的技术文章已经写到第四篇了&#xff01; 今天和大家介绍的一个项目属于音频领域的ChatGPT的应用实践。真没想不到&#xff0c;在音频领域&#xff0c;ChatGPT都没有放过&#xff0c…

maven聚合工程详解

目录 一、Maven继承二、idea搭建父子工程三、可继承的 POM 元素四、Maven聚合五、idea搭建聚合工程六、继承和聚合的关系七、dependencyManagement八、pluginManagement 本篇文章重点针对这几个问题进行讲解&#xff1a; Maven继承使用IDEA搭建Maven父子工程使用IDEA搭建Maven…

【建议收藏】Python自动化必不可少的测试框架 — pytest

每天进步一点点&#xff0c;关注我哦&#xff0c;每天分享测试技术文章 Python在测试圈的应用非常广泛&#xff0c;特别是在自动化测试以及测试开发的领域&#xff0c;其中在自动化测试中我们常用的测试框架是uniitest和pytest&#xff0c;本文将带领大家搭建以及熟悉pytest的使…

改进YOLOv5系列:ResNeXt融合特征金字塔,引领YOLOv5目标检测

目录 一、介绍1、YOLOv5简介2、ResNeXt简介3、目标检测简介 二、YOLOv5及其局限性1、YOLOv5的架构与原理2、YOLOv5的优势3、YOLOv5的局限性 三、ResNeXt与特征金字塔融合1、ResNeXt的基本原理2、ResNeXt的优势3、特征金字塔的基本原理4、特征金字塔的优势5、ResNeXt与特征金字塔…

mysql JDBC的三种查询(普通、流式、游标)

使用JDBC向mysql发送查询时&#xff0c;有三种方式&#xff1a; 常规查询&#xff1a;JDBC驱动会阻塞的一次性读取全部查询的数据到 JVM 内存中&#xff0c;或者分页读取流式查询&#xff1a;每次执行rs.next时会判断数据是否需要从mysql服务器获取&#xff0c;如果需要触发读…

找计算机研究的论文18个平台

虽然说目前arvix是计算机领域跟进最新研究成果论文的网站&#xff0c;有时候我们也需要找一些其他的好论文&#xff0c;比如一个很久之前的。我们整理了18个相关平台&#xff0c;包括几个可以免费下载和阅读CS相关技术论文的网站&#xff0c;收录到 找计算机研究的论文18个平台…

secure CRT 常见问题配置

文章目录 颜色主题如何切换 SecureCRT 颜色主题如何新建SecureCRT 颜色 主题如何拷贝我的颜色主题,主题名为pic 系统间拷贝基于clipboard的文字shell下的VIM系统间拷贝1. 确保 ubuntu 上的 vim 支持 clipboard 特性2. 确保 图形shell下的 vim(gvim) 支持 系统间拷贝3. 确保 文字…

004 - STM32固件库GPIO(三)位带操作

目前掌握的对GPIO引脚的输入输出操作只能使用BSRRL/H、I/ODR寄存器&#xff0c;记得以前学51的时候&#xff0c;对于引脚的输入输出可以采用关键字sbit实现位定义,例如 sbit LED1 P1^3;在STM32中没有类似于sbit一样的关键字&#xff0c;但是提供了位带操作来实现类似于51的为…