在一个JPA Entity中定义了java.util.Date类型的LastUpdateTime 和 CreateTime 两个字段实例。
现在想要的需求是在执行 EntityManager 的 persist 方法(即执行SQL 的Insert)时 会自动给 CreateTime和 LastUpdateTime一个当前时间的初始值,以后执行 EntityManager 的 merge 方法(即执行SQL 的update)时,自动给 LastUpdateTime 一个当前时间值,同时忽略 CreateTime 的修改。
有没有JPA 的注解可以实现这个需求?因为是用Hibernate4.0实现的JPA ,所以有没有Hibernate 的注解可以实现这个需求?
其实最麻烦的就是 每次 merge 的时候忽略 CreateTime 字段的更新值,不然每次更新时都要先获取一次数据后塞回给entity,再执行merge,这样效率非常低下啊。
因为用的是MySQL,所以 LastUpdateTime 我定义成 "TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP"
,但是发现没有意义,如果偷懒不在代码中给 LastUpdateTime赋值,JPA 会自动给它赋值为Null。
LastUpdateTime 的定义改了一下: "TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP"
这样每次JPA Update NULL 值给 LastUpdateTime 时,数据库会自动给它赋值位当前时间。 就是CreateTime这个限制更新不知怎么搞。
@PrePersist
public void prePersist(){
this.updateBy = UserUtils.getUser();
this.updateDate = new Date();
this.createBy = this.updateBy;
this.createDate = this.updateDate;
}
@PreUpdate
public void preUpdate(){
this.updateBy = UserUtils.getUser();
this.updateDate = new Date();
}
放在BaseEntity里面去
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。