JPA Audit
在spring jpa中,支持在字段或者方法上进行注解@CreatedDate、@CreatedBy、@LastModifiedDate、@LastModifiedBy,从字面意思可以很清楚的了解,这几个注解的用处。
@CreatedDate : 表示该字段为创建时间时间字段,在这个实体被insert的时候,会设置值
@CreatedBy : 表示该字段为创建人,在这个实体被insert的时候,会设置值
@LastModifiedDate、@LastModifiedBy同理。
如何使用?
首先申明实体类,需要在类上加上注解@EntityListeners(AuditingEntityListener.class),其次在application启动类中加上注解EnableJpaAuditing,同时在需要的字段上加上@CreatedDate、@CreatedBy、@LastModifiedDate、@LastModifiedBy等注解。
这个时候,在jpa.save方法被调用的时候,时间字段会自动设置并插入数据库,但是CreatedBy和LastModifiedBy并没有赋值,因为需要实现AuditorAware接口来返回你需要插入的值。
Application
@SpringBootApplication @EnableJpaAuditing public class WalletApplication { public static void main(String[] args) { new SpringApplicationBuilder(WalletApplication.class).web(true).run(args); } }
AuditorAware
@Configuration public class AuditorConfig implements AuditorAware<User> { @Override public Optional<User> getCurrentAuditor() { Subject subject = SecurityUtils.getSubject(); User user = (User) subject.getPrincipal(); return Optional.ofNullable(user); } }
Entity
@Entity @Table(name = "vendor") @Getter @Setter @EntityListeners(AuditingEntityListener.class) public class Vendor implements Serializable { private static final long serialVersionUID = -8506513792530949744L; @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(name = "name", nullable = false) private String name; @OneToMany(mappedBy = "vendor", cascade = {CascadeType.PERSIST}, fetch = FetchType.LAZY) private List<Mobile> mobiles; @CreatedDate @Column(name = "create_date") private Date createDate; @LastModifiedDate @Column(name = "update_date") private Date updateDate; @CreatedBy @ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name = "create_by") @JsonIgnore private User createBy; @LastModifiedBy @ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name = "update_by") @JsonIgnore private User lastModifiedBy; @Column(name = "delete_flag", nullable = false, columnDefinition = "INT default 0") @Size(max = 1) private int deleteFlag; }
还没有评论,来说两句吧...