使用注解自动保存数据的维护时间和修改者

通常来说,我们都有这样的需求:我需要知道库中的数据是由谁创建,什么时候创建,最后一次修改时间是什么时候,最后一次修改人是谁。

在Spring jpa中可以通过在实体bean的属性或者方法上添加以下注解来实现上述需求@CreatedDate、@CreatedBy、@LastModifiedDate、@LastModifiedBy。

  • @CreatedDate 表示该字段为创建时间时间字段,在这个实体被insert的时候,会设置值
  • @CreatedBy 表示该字段为创建人,在这个实体被insert的时候,会设置值
  • @LastModifiedDate 最后修改时间 实体被update的时候会设置
  • @LastModifiedBy 最后修改人 实体被update的时候会设置

使用方式

实体类添加注解

  • 首先在实体中对应的字段加上上述4个注解
  • 在material-admin中我们提取了一个基础实体类BaseEntity,并将对应的字段添加上述4个注解,所有需要记录维护信息的表对应的实体都集成该类
  1. import org.springframework.data.annotation.CreatedBy;
  2. import org.springframework.data.annotation.CreatedDate;
  3. import org.springframework.data.annotation.LastModifiedBy;
  4. import org.springframework.data.annotation.LastModifiedDate;
  5. import javax.persistence.Column;
  6. import javax.persistence.GeneratedValue;
  7. import javax.persistence.Id;
  8. import javax.persistence.MappedSuperclass;
  9. import java.io.Serializable;
  10. import java.util.Date;
  11. @MappedSuperclass
  12. @Data
  13. public abstract class BaseEntity implements Serializable {
  14. @Id
  15. @GeneratedValue
  16. private Long id;
  17. @CreatedDate
  18. @Column(name = "create_time",columnDefinition="DATETIME COMMENT '创建时间/注册时间'")
  19. private Date createTime;
  20. @Column(name = "create_by",columnDefinition="bigint COMMENT '创建人'")
  21. @CreatedBy
  22. private Long createBy;
  23. @LastModifiedDate
  24. @Column(name = "modify_time",columnDefinition="DATETIME COMMENT '最后更新时间'")
  25. private Date modifyTime;
  26. @LastModifiedBy
  27. @Column(name = "modify_by",columnDefinition="bigint COMMENT '最后更新人'")
  28. private Long modifyBy;
  29. }

实现AuditorAware接口返回操作人员的id

配置完上述4个注解后,在jpa.save方法被调用的时候,时间字段会自动设置并插入数据库,但是CreatedBy和LastModifiedBy并没有赋值这两个信息需要实现AuditorAware接口来返回操作人员的id

  • 首先需要在项目启动类添加@EnableJpaAuditing 注解来启用审计功能
  1. @SpringBootApplication
  2. @EnableJpaAuditing
  3. public class AdminApplication extends WebMvcConfigurerAdapter {
  4. //省略
  5. }
  • 然后实现AuditorAware接口返回操作人员的id
  1. @Configuration
  2. public class UserIDAuditorConfig implements AuditorAware<Long> {
  3. @Override
  4. public Optional<Long> getCurrentAuditor() {
  5. ShiroUser shiroUser = ShiroKit.getUser();
  6. if(shiroUser!=null){
  7. return Optional.of(shiroUser.getId());
  8. }
  9. return Optional.of(Constants.SYSTEM_USER_ID);
  10. }
  11. }