数据库设计>>>创建时间/更新时间自动填充@TOC
创建时间/更新时间自动填充
阿里巴巴开发手册:所有的数据库表都要配置上gmt_create、gmt_modified!而且需要自动化!
方式一
数据库级别(工作中一般不用, 这种方式不用代码实现,数据库自动填充)
1、在表中新增字段 gmt_create, gmt_modified
2、把实体类同步
private Date gmtCreate;
private Date gmtModified;
3、数据库设计
测试:
更新一条记录
@Test
void upDataUser() {
User user = new User();
user.setId(1347883372479614979L);
user.setName("刘德华");
user.setAge(58);
user.setEmail("1820818361@qq.com");
int result = userMapper.updateById(user);
System.out.println("result>>>" + result);
System.out.println("user" + user);
}
更新后的结果:
方式二:代码级别
1、数据库字段
2、实体类字段属性上需要增加注解
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
@TableId(type = IdType.AUTO)
private Long id;
private String name;
private Integer age;
private String email;
@TableField(value = "gmt_create",fill = FieldFill.INSERT)
private LocalDateTime gmtCreate;
@TableField( value = "gmt_modified",fill = FieldFill.INSERT_UPDATE)
private LocalDateTime gmtModified;
}
3、编写处理器来处理这个注解即可!(可以参考官网)
“gmtModified” 指的是实体类属性的名字 还有要注意日期类型一样
package link.zishu.handler;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;
import java.util.Date;
@Component // 一定不要忘记把处理器加到IOC容器中!
public class MyMetaObjectHandler implements MetaObjectHandler {
// 插入时的填充策略
@Override
public void insertFill(MetaObject metaObject) {
System.out.println("start insert fill.....");
this.strictInsertFill(metaObject, "gmtCreate", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)
this.strictInsertFill(metaObject, "gmtModified", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)
}
// 更新时的填充策略
@Override
public void updateFill(MetaObject metaObject) {
//"gmtModified" 指的是实体类属性的名字 还有要注意日期类型一样
this.strictUpdateFill(metaObject, "gmtModified", LocalDateTime.class, LocalDateTime.now());
}
}
测试
@Test
void upDataUser() {
User user = new User();
user.setId(1347883372479614988L);
user.setName("刘德华");
user.setAge(58);
user.setEmail("1820818361@qq.com");
int result = userMapper.updateById(user);
System.out.println("result>>>" + result);
System.out.println("user" + user);
}
结果
附 (注解填充字段的选项)
public enum FieldFill {
/**
* 默认不处理
*/
DEFAULT,
/**
* 插入填充字段
*/
INSERT,
/**
* 更新填充字段
*/
UPDATE,
/**
* 插入和更新填充字段
*/
INSERT_UPDATE
}