mybatis plus 配置自动设置创建时间和创建人id

1.新建 MyMetaObjectHandler

复制代码
package com.ruoyi.framework.config;

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import com.ruoyi.common.bean.LocalUser;
import com.ruoyi.coupon.domain.CouponUser;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;

import java.util.Date;

/**
 * 自动插入时间和操作人id
 */
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        this.setFieldValByName("createTime",new Date(),metaObject);
        CouponUser user = LocalUser.getUser();
        if(user != null){
            this.setFieldValByName("createBy",String.valueOf(user.getId()),metaObject);
        }
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        this.setFieldValByName("updateTime",new Date(),metaObject);
        CouponUser user = LocalUser.getUser();
        if(user != null){
            this.setFieldValByName("updateBy",String.valueOf(user.getId()),metaObject);
        }
    }
}

2.待自动设置字段加注解

复制代码
public class BaseEntity implements Serializable
{

    /** 创建者 */
    @TableField(fill = FieldFill.INSERT)
    private String createBy;

    /** 创建时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;

    /** 更新者 */
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private String updateBy;

    /** 更新时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;
}

2.如果无效,则需要加入一下配置

复制代码
@Bean
    public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception
    {
        String typeAliasesPackage = env.getProperty("mybatis-plus.typeAliasesPackage");
        String mapperLocations = env.getProperty("mybatis-plus.mapperLocations");
        String configLocation = env.getProperty("mybatis-plus.configLocation");
        typeAliasesPackage = setTypeAliasesPackage(typeAliasesPackage);
        VFS.addImplClass(SpringBootVFS.class);

        final MybatisSqlSessionFactoryBean sessionFactory = new MybatisSqlSessionFactoryBean ();
        sessionFactory.setDataSource(dataSource);
        sessionFactory.setTypeAliasesPackage(typeAliasesPackage);
        sessionFactory.setMapperLocations(resolveMapperLocations(StringUtils.split(mapperLocations, ",")));
        sessionFactory.setConfigLocation(new DefaultResourceLoader().getResource(configLocation));

        //获取mybatis-plus全局配置
        GlobalConfig globalConfig = GlobalConfigUtils.defaults();
        //mybatis-plus全局配置设置元数据对象处理器为自己实现的那个
        globalConfig.setMetaObjectHandler(new MyMetaObjectHandler());
        sessionFactory.setGlobalConfig(globalConfig);
        
        return sessionFactory.getObject();
    }

至此完成

相关推荐
java1234_小锋15 小时前
说说MyBatis的工作原理吗?
java·mybatis
是宇写的啊16 小时前
MyBaties
java·开发语言·mybatis
那个失眠的夜17 小时前
RESTful 语法规范 核心注解详解
java·spring·mvc·mybatis
他是龙55118 小时前
66:Java安全&SPEL表达式&SSTI模版注入&XXE&JDBC&MyBatis注入
java·安全·mybatis
MegaDataFlowers1 天前
MybatisPlus入门案例
mybatis
cheems95272 天前
[Mybatis] #{ } 与 ${ } 的底层博弈与工程实践
mybatis
2601_949817722 天前
Spring Boot3.3.X整合Mybatis-Plus
spring boot·后端·mybatis
LaLaLa_OvO2 天前
mybatis 引用静态常量
java·mybatis
yaodong5182 天前
Spring 中使用Mybatis,超详细
spring·tomcat·mybatis
2601_949815332 天前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis