当前位置: 首页 > news >正文

MyBatis-Plus自动填充

文章目录

  • 一、前言
  • 二、MyBatis-Plus自动填充功能实现
    • 2.1、实体类上增加注解
    • 2.2、自定义填充类编写

一、前言

我们在建表的时候,所有的表都会有create_id(创建人id)create_time(创建时间)update_id(更新人id)、**update_time(更新时间)**这几个字段,属于是公共字段。

image-20230726102807648

  • 在新增数据时:将创建人、更新人设置成当前系统登录人,将创建时间、更新时间设置成当前时间
  • 在更新数据时:将更新人设置成当前系统登录人,将更新时间设置成当前时间

因为每张表里都有这些字段,而每次我们新增修改数据,都需要更新这些字段,即使是抽出共通方法,代码也很冗余

二、MyBatis-Plus自动填充功能实现

官方文档地址:https://baomidou.com/pages/4c6bcf/

2.1、实体类上增加注解

在需要自动填充的实体类字段上需要加上注解,这里推荐建一个共通父类,所有实体类都继承该父类,避免在每个实体类中重复编写

image-20230726110211132

2.2、自定义填充类编写

写一个类实现 com.baomidou.mybatisplus.core.handlers.MetaObjectHandler 接口,实现其 insertFill(MetaObject metaObject) 方法和 updateFill(MetaObject metaObject) 方法

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {@Overridepublic void insertFill(MetaObject metaObject) {String userId = getUserId();this.strictInsertFill(metaObject, "createId", String.class, userId);this.strictInsertFill(metaObject, "updateId", String.class, userId);this.strictInsertFill(metaObject, "createTime", Date.class, new Date());this.strictInsertFill(metaObject, "updateTime", Date.class, new Date());}@Overridepublic void updateFill(MetaObject metaObject) {String userId = getUserId();this.strictUpdateFill(metaObject, "updateId", String.class, userId);this.strictUpdateFill(metaObject, "updateTime", Date.class, new Date());}private String getUserId() {//自己实现,从上下文中获取当前登录的用户id}}

这里使用的是 strictInsertFillstrictUpdateFill 这种严格字段填充,不仅字段名称、字段类型要和数据库一致,而且实体类中这些要填充的字段要是空的时候,才会填充

http://www.lryc.cn/news/97444.html

相关文章:

  • Dubbo服务提供者失效踢出原理解析
  • el-select下拉框处理分页数据,触底加载更多
  • 如何设计自动化测试脚本?一文5个步骤带你从0到1设计
  • PostgreSQL实战-数据库迁移部署
  • PHP数据库
  • Mybatis的基本操作--增删改查
  • Qt简单实现密码器控件
  • fpga_pwm呼吸灯(EP4CE6F17C8)
  • WPF实战学习笔记20-设置首页启动页
  • uniapp实现预约时间选择弹窗组件
  • opencv 之 外接多边形(矩形、圆、三角形、椭圆、多边形)使用详解
  • 断路器分合闸速断试验
  • 【Redis】如何实现一个合格的分布式锁
  • 组件化开发复习
  • 【设计模式】设计原则-里氏替换原则
  • v2ex站点base64编码解码
  • PostgreSQL数据库动态共享内存管理器——Dynamic shared memory areas
  • Redission分布式锁详解
  • 063、故障处理之快速恢复数据
  • 从零开始学习CTF
  • 【stable diffusion】保姆级入门课程05-Stable diffusion(SD)图生图-涂鸦重绘的用法
  • HBase 源码编译部署包
  • 备战秋招 | 笔试强训16
  • 01 Excel常用高频快捷键汇总
  • PHP Laravel 路由、中间件、数据库等例子
  • Unity小游戏——使被砍中的怪物四处飞散
  • hive之文件格式与压缩
  • 云原生容器内的一次pg_repack排错和解决过程
  • Centos Certbot 使用
  • VL163的基本信息