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();
    }

至此完成

相关推荐
陌路202 小时前
redis缓存雪崩,击穿,穿透
redis·缓存·mybatis
学习编程的Kitty17 小时前
Redis(1)——持久化
数据库·redis·mybatis
利刃大大18 小时前
【Mybatis】Mybatis入门 && 基础操作 && XML配置文件开发 && 多表查询 && 注入问题 && 数据库连接池
xml·数据库·mybatis
野蛮人6号1 天前
黑马微服务报错以及解决前23节课
spring boot·微服务·mybatis
悟能不能悟1 天前
mybatis sql where a=#{a},如果a为null,会返回什么
数据库·sql·mybatis
running up2 天前
MyBatis 核心知识点与实战
数据库·oracle·mybatis
落霞的思绪2 天前
Mybatis读取PostGIS生成矢量瓦片实现大数据量图层的“快显”
linux·运维·mybatis·gis
自在极意功。2 天前
MyBatis配置文件详解:environments、transactionManager与dataSource全面解析
java·数据库·tomcat·mybatis
苏小瀚2 天前
[JavaEE] Spring IoC&DI
spring·java-ee·mybatis
星星不打輰3 天前
SSM项目--SweetHouse 甜蜜蛋糕屋
java·spring·mybatis·ssm·springmvc