当我们使用mybatis对一个实体进行插入或者更新的时候,如何对指定字段默认生成值,不用每次自己去赋值,下面将告诉大家,我会以新增时间和更新时间为例,其他的相似。
1.首先在实体字段加上注解@TableField
public class BaseEntity implements Serializable
{
private static final long serialVersionUID = 1L;
/** 创建时间 */
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone="GMT+8")
@TableField(fill = FieldFill.INSERT)
private Date createTime;
/** 更新时间 */
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone="GMT+8")
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
public Date getCreateTime()
{
return createTime;
}
public void setCreateTime(Date createTime)
{
this.createTime = createTime;
}
public Date getUpdateTime()
{
return updateTime;
}
public void setUpdateTime(Date updateTime)
{
this.updateTime = updateTime;
}
}
2.具体赋值配置
package com.hzrc.commonserver.config;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import org.springframework.util.ObjectUtils;
import java.util.Date;
/**
* 自动生成时间
*/
@Component
public class MyDetaObjectHander implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
Object createTime = getFieldValByName("createTime", metaObject);
if(ObjectUtils.isEmpty(createTime)) {
this.setFieldValByName("createTime",new Date(),metaObject);
}
Object updateTime = getFieldValByName("updateTime", metaObject);
if(ObjectUtils.isEmpty(updateTime)) {
this.setFieldValByName("updateTime",new Date(),metaObject);
}
}
@Override
public void updateFill(MetaObject metaObject) {
this.setFieldValByName("updateTime",new Date(),metaObject);
}
}
这样就达到了,当我们对BaseEntity赋值的时候,会自动对createTime和updateTime附上对应类型的值。
知是行之始,行是知之成
本文暂时没有评论,来添加一个吧(●'◡'●)