zoukankan      html  css  js  c++  java
  • MybatisPlus的自动填充功能使用!

    有时我们希望在更新数据的时候,自动完成某些字段的值的填充,如创建一个实体的时候,自动生成创建时间,更新的时候自动改变更新时间等。

    • 在指定字段标注注解,生成器策略部分也可以配置。
        // 创建时间
        @TableField(fill = FieldFill.INSERT)
        private Date createTime;
    
        // 更新时间
        @TableField(fill = FieldFill.INSERT_UPDATE)
        private Date updateTime;
    
    public enum FieldFill {
        /**
         * 默认不处理
         */
        DEFAULT,
        /**
         * 插入填充字段
         */
        INSERT,
        /**
         * 更新填充字段
         */
        UPDATE,
        /**
         * 插入和更新填充字段
         */
        INSERT_UPDATE
    }
    
    • 实现元对象处理接口:com.baomidou.mybatisplus.core.handlers.MetaObjectHandler
    @Slf4j
    @Component
    public class MyMetaObjectHandler implements MetaObjectHandler {
    
        // fieldName 指的是实体类的属性名,而不是数据库的字段名
        @Override
        public void insertFill(MetaObject metaObject) {
            log.info("start insert fill ....");
            this.strictInsertFill(
                metaObject, "createTime", LocalDateTime.class, LocalDateTime.now());
            this.strictInsertFill(
                metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());
        }
    
        @Override
        public void updateFill(MetaObject metaObject) {
            log.info("start update fill ....");
            this.strictUpdateFill(
                // 起始版本 3.3.0(推荐)
                metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());
            // 或者
            this.strictUpdateFill(
                // 起始版本 3.3.3(推荐)
                metaObject, "updateTime", LocalDateTime::now, LocalDateTime.class); 
        }
    }
    

  • 相关阅读:
    第十章、数据库运行维护与优化
    第九章、安全管理
    第八章、数据库后台编程技术
    第七章、高级数据库查询
    第六章、数据库及数据库对象
    第五章、UML与数据库应用系统
    第四章、数据库应用系统功能设计与实施
    struts2标签debug
    SSH框架 more than one namespace has been specificed without a prefix
    Http Status 404
  • 原文地址:https://www.cnblogs.com/summerday152/p/13878176.html
Copyright © 2011-2022 走看看