您当前的位置:首页 > 电脑百科 > 程序开发 > 框架

SpringBoot整合MybatisPlus数据自动填充

时间:2022-03-18 11:06:04  来源:  作者:死牛胖子

SpringBoot 集成 MyBatisPlus 系列

SpringBoot 版本:2.6.4
MybatisPlus 版本:3.5.1

  • SpringBoot整合MybatisPlus
  • SpringBoot整合MybatisPlus数据自动填充
  • SpringBoot整合MybatisPlus实现逻辑删除
  • SpringBoot整合MybatisPlus实现分页查询
  • SpringBoot整合MybatisPlus支持枚举类型
  • 未完待续…

SpringBoot整合MybatisPlus数据自动填充

 

在真实的项目里,表结构中一般会存在一些公司内部约定的公共字段,比如:创建时间,创建人,修改时间,修改人等,记录这些数据一方面可以出现问题时进行溯源,也可以提供给大数据收集。

不管怎样,这是目前大部分公司选择的方案。

通常公司的框架会有一个上下文对象,存储了当前登录人信息,每次新增或者修改数据库记录,可以从上下文中获取当前登录人信息,填充创建时间,创建人这些信息。但如果每次都需要手动去写这些业务无关的内容,重复且繁琐,而且还容易出错。

需求分析

假设增加 createTime、createUser、updateTime、updateUser 四个字段用来记录创建时间,创建人,修改时间,修改人信息。

  • 新增记录时,四个字段都进行填充
  • 修改记录时,只填充 updateTime、updateUser 两个字段,createTime、createUser 则保持不变

准备工作

使用 MySQL 数据库,设计一张 user 表。

数据库脚本

CREATE TABLE user (
    `id` BIGINT(20) NOT NULL COMMENT '主键',
    `name` VARCHAR(32) NOT NULL COMMENT '姓名',
    `age` SMALLINT(4) NOT NULL DEFAULT '0' COMMENT '年龄',
    `emAIl` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '邮箱',
    `create_time` DATETIME NOT NULL COMMENT '创建时间',
    `create_user` VARCHAR(32) NOT NULL COMMENT '创建人',
    `update_time` DATETIME NOT NULL COMMENT '最近更新时间',
    `update_user` VARCHAR(32) NOT NULL COMMENT '最近更新人',
    PRIMARY KEY (id)
)
SpringBoot整合MybatisPlus数据自动填充

 

整合 MybatisPlus 实现自动填充

第一步:设置 @TableField 注解的 FieldFill 属性

其实每个字段都默认设置了一个 @TableField,所以 MybatisPlus 实体类中的字段都必须与数据库表中的字段对应,可以少,但不能多,多出来的字段必须设置 @TableField(exist = false)。

@TableField 注解中还有一个属性 fill,就是用于支持自动填充功能,可选择的值有四个

  • DEFAULT:默认值,不自动填充
  • INSERT:插入时自动填充
  • UPDATE:更新时自动填充
  • INSERT_UPDATE:插入及更新时自动填充

根据本次的需求,为 createTime、createUser、updateTime、updateUser 四个字段分别添加自动填充策略

@Data
public class User {
    @TableId(type = IdType.ASSIGN_ID)
    private Long id;
    private String name;
    private Integer age;
    private String email;
    @TableField(fill = FieldFill.INSERT)
    private LocalDateTime createTime;
    @TableField(fill = FieldFill.INSERT)
    private String createUser;
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updateTime;
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private String updateUser;
}

第二步:实现 MetaObjectHandler 接口

通过第一步,设置好的填充的时机,但具体该填充什么值,则需要实现 MetaObjectHandler 接口(为了简化,这里处理人姓名写死了,正常可以通过上下文进行获取)。

这个类需要注册到 Spring 容器中

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    // 新增时填充
    @Override
    public void insertFill(MetaObject metaObject) {
        LocalDateTime now = LocalDateTime.now();
        this.strictInsertFill(metaObject, "createTime", () -> now, LocalDateTime.class);
        this.strictInsertFill(metaObject, "createUser", () -> "haha", String.class);
        this.strictInsertFill(metaObject, "updateTime", () -> now, LocalDateTime.class);
        this.strictInsertFill(metaObject, "updateUser", () -> "haha", String.class);
    }
    // 修改时填充
    @Override
    public void updateFill(MetaObject metaObject) {
        this.strictUpdateFill(metaObject, "updateTime", LocalDateTime::now, LocalDateTime.class);
        this.strictUpdateFill(metaObject, "updateUser", () -> "haha", String.class);
    }
}

MetaObjectHandler 中声明填充的字段,如果实体类中有,则会进行填充,如果没有,也可以正常运行,填充动作被忽略

测试

编写测试用例

@RunWith(SpringRunner.class)
@SpringBootTest(classes = Application.class)
public class MybatisPlusTest {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void testInsert() {
        User user = new User();
        user.setId(10);
        user.setUsername("test");
        userMapper.insert(user);
    }
}

查看日志输出如下,deleted 查询条件已自动加上

==>  Preparing: INSERT INTO user (id, name, create_time, create_user, update_time, update_user) VALUES ( ?, ?, ?, ?, ?, ? )
==>  Parameters: 10(Long), test(String), 2022-03-11T20:32:31.532(LocalDateTime), haha(String), 2022-03-11T20:32:31.532(LocalDateTime), haha(String)
<==  Updates: 1

修改的测试用例请自行编写

总结

自动填充主要用途还是将一些与业务无关的字段,使用公共代码进行填充,减少业务处理时还要兼顾非业务字段,让业务代码更纯粹。

MybatisPlus 支持的逻辑删除功能,新增时需要对逻辑删除标记字段填充一个默认值,也可以使用自动填充功能进行填充。



Tags:MybatisPlus   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
MyBatisPlus逻辑删除与唯一索引的兼容问题
需求背景比如有张用户表,在插入或者更新数据的时候,我们需要 用户名称(username),不能重复。我们首先考虑的是给该字段创建唯一索引create unique index uni_username on use...【详细内容】
2023-04-04  Search: MybatisPlus  点击:(185)  评论:(0)  加入收藏
MybatisPlus生成器ServiceImpl类详解
ServiceImpl类是我们进行SQL操作中非常重要的一个类,通过MybatisPlus生成的各个实体类的XXXImpl都会继承ServiceImpl类那里继承全部的方法,那么ServiceImpl类中有哪些方法呢?如...【详细内容】
2022-08-03  Search: MybatisPlus  点击:(1285)  评论:(0)  加入收藏
MyBatisPlus又在搞事了!发布神器,一个依赖轻松搞定权限问题
今天介绍一个 MyBatis - Plus 官方发布的神器:mybatis-mate 为 mp 企业级模块,支持分库分表,数据审计、数据敏感词过滤(AC算法),字段加密,字典回写(数据绑定),数据权限,表结构自动生成...【详细内容】
2022-06-17  Search: MybatisPlus  点击:(267)  评论:(0)  加入收藏
学会了MybatisPlus,代码开发效率提高了10倍
1. Mybatis 存在的痛点我们知道 MyBatis 是一个基于 java 的持久层框架,它内部封装了 jdbc,极大提高了我们的开发效率。但是使用 Mybatis 开发也有很多痛点: 每个 Dao 接口都需...【详细内容】
2022-06-14  Search: MybatisPlus  点击:(406)  评论:(0)  加入收藏
SpringBoot整合MybatisPlus基本的增删改查,保姆级教程
MybatisPlus是国产的第三方插件, 它封装了许多常用的CURDapi,免去了我们写mapper.xml的重复劳动,这里介绍了基本的整合SpringBoot和基础用法。2|0引入依赖在项目中pom文件引入m...【详细内容】
2022-05-05  Search: MybatisPlus  点击:(298)  评论:(0)  加入收藏
SpringBoot整合MybatisPlus数据自动填充
SpringBoot 集成 MybatisPlus 系列SpringBoot 版本:2.6.4 MybatisPlus 版本:3.5.1 SpringBoot整合MybatisPlus SpringBoot整合MybatisPlus数据自动填充 SpringBoot整合Mybatis...【详细内容】
2022-03-18  Search: MybatisPlus  点击:(579)  评论:(0)  加入收藏
MybatisPlus中实体类属性对应枚举类实现
一、前言1.1、关于枚举类① 枚举是JDK1.5中的新功能,我们可以使用枚举很好的去描述一些业务场景:一年有四季、人类有男女...② 同样我们在业务层面会有很多,比如状态属性、分...【详细内容】
2022-01-20  Search: MybatisPlus  点击:(668)  评论:(0)  加入收藏
用了MybatisPlus后,我很久没有手写sql了
(一)前言最早写JDBC的时候,要手动配连接信息,要一条条手写sql语句。后来Mybatis出现了,不需要再手动配置连接信息,sql语句也和代码隔离开来,但是还免不了写Sql。接着出现了MybatisP...【详细内容】
2021-09-17  Search: MybatisPlus  点击:(384)  评论:(0)  加入收藏
▌简易百科推荐
Qt与Flutter:在跨平台UI框架中哪个更受欢迎?
在跨平台UI框架领域,Qt和Flutter是两个备受瞩目的选择。它们各自具有独特的优势,也各自有着广泛的应用场景。本文将对Qt和Flutter进行详细的比较,以探讨在跨平台UI框架中哪个更...【详细内容】
2024-04-12  刘长伟    Tags:UI框架   点击:(6)  评论:(0)  加入收藏
Web Components实践:如何搭建一个框架无关的AI组件库
一、让人又爱又恨的Web ComponentsWeb Components是一种用于构建可重用的Web元素的技术。它允许开发者创建自定义的HTML元素,这些元素可以在不同的Web应用程序中重复使用,并且...【详细内容】
2024-04-03  京东云开发者    Tags:Web Components   点击:(8)  评论:(0)  加入收藏
Kubernetes 集群 CPU 使用率只有 13% :这下大家该知道如何省钱了
作者 | THE STACK译者 | 刘雅梦策划 | Tina根据 CAST AI 对 4000 个 Kubernetes 集群的分析,Kubernetes 集群通常只使用 13% 的 CPU 和平均 20% 的内存,这表明存在严重的过度...【详细内容】
2024-03-08  InfoQ    Tags:Kubernetes   点击:(22)  评论:(0)  加入收藏
Spring Security:保障应用安全的利器
SpringSecurity作为一个功能强大的安全框架,为Java应用程序提供了全面的安全保障,包括认证、授权、防护和集成等方面。本文将介绍SpringSecurity在这些方面的特性和优势,以及它...【详细内容】
2024-02-27  风舞凋零叶    Tags:Spring Security   点击:(59)  评论:(0)  加入收藏
五大跨平台桌面应用开发框架:Electron、Tauri、Flutter等
一、什么是跨平台桌面应用开发框架跨平台桌面应用开发框架是一种工具或框架,它允许开发者使用一种统一的代码库或语言来创建能够在多个操作系统上运行的桌面应用程序。传统上...【详细内容】
2024-02-26  贝格前端工场    Tags:框架   点击:(50)  评论:(0)  加入收藏
Spring Security权限控制框架使用指南
在常用的后台管理系统中,通常都会有访问权限控制的需求,用于限制不同人员对于接口的访问能力,如果用户不具备指定的权限,则不能访问某些接口。本文将用 waynboot-mall 项目举例...【详细内容】
2024-02-19  程序员wayn  微信公众号  Tags:Spring   点击:(41)  评论:(0)  加入收藏
开发者的Kubernetes懒人指南
你可以将本文作为开发者快速了解 Kubernetes 的指南。从基础知识到更高级的主题,如 Helm Chart,以及所有这些如何影响你作为开发者。译自Kubernetes for Lazy Developers。作...【详细内容】
2024-02-01  云云众生s  微信公众号  Tags:Kubernetes   点击:(56)  评论:(0)  加入收藏
链世界:一种简单而有效的人类行为Agent模型强化学习框架
强化学习是一种机器学习的方法,它通过让智能体(Agent)与环境交互,从而学习如何选择最优的行动来最大化累积的奖励。强化学习在许多领域都有广泛的应用,例如游戏、机器人、自动驾...【详细内容】
2024-01-30  大噬元兽  微信公众号  Tags:框架   点击:(71)  评论:(0)  加入收藏
Spring实现Kafka重试Topic,真的太香了
概述Kafka的强大功能之一是每个分区都有一个Consumer的偏移值。该偏移值是消费者将读取的下一条消息的值。可以自动或手动增加该值。如果我们由于错误而无法处理消息并想重...【详细内容】
2024-01-26  HELLO程序员  微信公众号  Tags:Spring   点击:(92)  评论:(0)  加入收藏
SpringBoot如何实现缓存预热?
缓存预热是指在 Spring Boot 项目启动时,预先将数据加载到缓存系统(如 Redis)中的一种机制。那么问题来了,在 Spring Boot 项目启动之后,在什么时候?在哪里可以将数据加载到缓存系...【详细内容】
2024-01-19   Java中文社群  微信公众号  Tags:SpringBoot   点击:(88)  评论:(0)  加入收藏
站内最新
站内热门
站内头条