美文网首页代码优化
表数据公共参数提取

表数据公共参数提取

作者: 半日孤独 | 来源:发表于2022-06-24 11:54 被阅读0次

背景

数据库业务表中都会有创建时间,创建人,更新时间和更新人字段,映射到实体类中,每次做业务都需要手动去给这几个赋值(当然时间也可以通过数据库自动更新),个人表示很麻烦,需要改造一手。

目的

在业务操作时,自动去给这几个字段赋值

实现方案

使用mybatisPlus(起始版本 3.3.0)框架中的FieldFill.INSERT(执行新增操作会更新字段)FieldFill.UPDATE(执行更新操作会更新字段) 进行处理

代码

 先把这几个属性抽取出来                            

@Data
@JsonInclude(JsonInclude.Include.NON_NULL)
public abstract class BaseCommonEntity implements Serializable {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty("创建人")
    @TableField(value = "create_by", fill = FieldFill.INSERT)
    private String createBy;

    @ApiModelProperty("创建时间")
    @TableField(value = "create_time", fill = FieldFill.INSERT)
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime createTime;

    @ApiModelProperty("更新人")
    @TableField(value = "update_by", fill = FieldFill.UPDATE)
    private String updateBy;

    @ApiModelProperty("更新时间")
    @TableField(value = "update_time", fill = FieldFill.INSERT_UPDATE)
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private LocalDateTime updateTime;

}
配置mybatisPlus配置
//重写mybatisplus中的字段填充器  ---mybatisplus起始版本 3.3.0(推荐使用)
@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        log.info("start insert fill ....");
        //新增时间
        this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now());
        //当前用户信息我们从springSecurity中获取
        if (UserIPUtil.getUserIsLoginIn()) {
            //新增创建人
            this.strictInsertFill(metaObject, "createBy", String.class, UserIPUtil.getCurrentUserId().toString());
        }
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        log.info("start update fill ....");
        // 更新时间
        this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());
        //当前用户信息我们从springSecurity中获取
        if (UserIPUtil.getUserIsLoginIn()) {
            //新增更新人
            this.strictUpdateFill(metaObject, "updateBy", String.class, UserIPUtil.getCurrentUserId().toString());
        }
    }

}
具体使用,我们只需要继承BaseCommonEntity就可以了 

相关文章

  • 表数据公共参数提取

    背景 数据库业务表中都会有创建时间,创建人,更新时间和更新人字段,映射到实体类中,每次做业务都需要手动去给这几个赋...

  • API用户体系设计和身份认证实践

    数据表 表 user 表 nonceuser_id + nonce 唯一 前端公共代码 后端公共代码 获得账号 a...

  • 使用wepy开发小程序-7|子组件向父组件传参

    子组件向父组件传递参数 首先看下需求 这是我们从公共接口菜谱里提取的数据,模拟饿了吗和美团的下单流程。按钮所在的是...

  • 30、Excel 数组分区 ETArrayPick

    函数名:ETArrayPick 函数功能:数组数据分区提取 应用场景: 1、对数组数据,分片区提取 参数:1...

  • H3BPM Controllers 优化方案

    查询参数优化,尽量使用对象。 InvokingLogController.cs 47 将公共方法提取到父类中,避免...

  • 能力资质库

    数据n : n资质表资质-参数、检验依据中间表参数表检验依据表中间表业务字段场所-是否全部认证 业务添加资质-参数...

  • 4.1 神经网络扩展

    ①自制数据集,解决本领域应用②数据增强,扩充数据集③断点续训,存取模型④参数提取,把参数存入文本⑤acc/loss...

  • 项目BaseActivity

    将公共部分提取 如:Toast,权限获取、验证、ButterKnife初始化、清理数据、弹框、顶部公共部分初始化、...

  • 跨表提取数据的妙招,秒杀函数高手

    跨表提取数据,小白的做法是复制粘贴,大神的做法是函数提取,超越大神的做法就是查询提取,在提取数据时还可以灵活编辑数...

  • VBA+SQL:提取数据(没有表头字段)

    表1数据是要提取的条件,数据没有重复,升序排列 表2是原始数据,k列是条件,对应表1的数据。 数据都是没有表头和字...

网友评论

    本文标题:表数据公共参数提取

    本文链接:https://www.haomeiwen.com/subject/cebvvrtx.html