使用MyBatisPlus进行字段的自动填充

2024-06-20 18:36

本文主要是介绍使用MyBatisPlus进行字段的自动填充,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用MyBatisPlus进行字段的自动填充

需求场景

当我们往数据库里面插入一条数据,或者是更新一条数据时,一般都需要标记创建时间create_time和更新时间update_time的值,但是如果我们每张表的每个请求,在执行sql语句的时候我们都手动写上create_time和update_time,那就显得有点太繁琐了,所以能不能简化这一操作呢?就是每次插入或者更新的时候,创建时间和更新时间能够自动更新,不用我们手动传递字段?可以的,我们可以使用MyBatisPlus的自动填充功能。

自动填充的原理

当执行插入语句或者是更新语句的时候,会被MybatisPlusInterceptor 拦截器拦截(官方说的是这个拦截器,但是我在本地测的并没有发现源代码中有这个拦截器,但是我发现了一个拦截分页查询的拦截器PaginationInterceptor,先暂且理解成是分页查询拦截器也可以进行字段填充,以后再逐步更新),拦截之后再根据反射获得我们插入的实体对象,然后往这个对象里面填充字段,这样就可以实现自动填充功能了。
要写一个实现MetaBojectHandler的实现类,如下图:
在这里插入图片描述
然后在执行插入或者是更新语句之前,会通过MyBatisPlus自带的拦截器拦截,如果你是执行的插入sql,那么就会进入到MetaObjectHandler接口的insertFill方法去执行填充逻辑,其中insertFill的参数MetaObject就能够通过反射获取到我们要插入的实体类对象,然后通过反射往对象里面填充属性值,如下图:
在这里插入图片描述

总的来说,原理就是:在sql语句执行之前,通过拦截器加反射的方式,往实体类对象里面填充属性

步骤

一共需要两步,第一步是写一个实现MetaObjectHandler接口的实现类,如下图:
在这里插入图片描述

第二步是在实体类里面通过注解指定存入数据库的数据格式并且和数据库字段映射,如下图:
在这里插入图片描述

验证结果

在postman里面发送个插入请求,如下图:
在这里插入图片描述
在数据库里面查看create_time和update_time是否被成功的插入进来,如下图:
在这里插入图片描述
可以发现插入成功。

不使用MyBatisPlus插件也可以直接往数据库里面填充创建时间更新时间

在做业务的时候,我就发现了一个非常神奇的点,就是我们的项目里面并没有使用MyBatisPlus插件关于填充数据的一些配置,但是数据库里面仍然是可以填充更新时间和创建时间的,这是为什么呢?这其实是navicat数据库软件帮我们做的,当设计表的时候,我们直接把create_time属性的值设置为current_timestamp格式,如下图:
在这里插入图片描述

代码参考

码云地址:https://gitee.com/xuanyuanzy/my-batis-plus/tree/master/src/main/java/org/example

这篇关于使用MyBatisPlus进行字段的自动填充的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1078929

相关文章

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

如何使用Lombok进行spring 注入

《如何使用Lombok进行spring注入》本文介绍如何用Lombok简化Spring注入,推荐优先使用setter注入,通过注解自动生成getter/setter及构造器,减少冗余代码,提升开发效... Lombok为了开发环境简化代码,好处不用多说。spring 注入方式为2种,构造器注入和setter

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、