JPA 怎样方便的定义LastUpdateTime 和 CreateTime 字段。

cokolin 发布于 2013/08/12 11:13
阅读 3K+
收藏 2

在一个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。

以下是问题补充:

@cokolin:LastUpdateTime 的定义改了一下: "TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP" 这样每次JPA Update NULL 值给 LastUpdateTime 时,数据库会自动给它赋值位当前时间。 就是CreateTime这个限制更新不知怎么搞。 (2013/08/12 13:21)
加载中
0
okjesse
okjesse
@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里面去
Big_BoBo
Big_BoBo
兄台功力深厚!O(∩_∩)O
0
蝶衣人生
蝶衣人生
Hibernate有的,我用过.
蝶衣人生
蝶衣人生
回复 @cokolin : 你直接实现SaveOrUpdateEventListener这个事件就行了.同时在DefaultSaveOrUpdateEventListener事件之前执行你的事件就行了
cokolin
cokolin
哪个啊?大哥,求教育
0
蝶衣人生
蝶衣人生

在hibernate的配置文件当中增加
<event type="save">
<listener class="net.osc.listener.SaveListener"/>
<listener class="org.hibernate.event.def.DefaultSaveOrUpdateEventListener"/>
</event>

0
箭头向下
箭头向下
用hibernate的拦截器可以实现。
0
xBinary
xBinary
问一下,为啥要用 timestamp 类型而不用 datetime 类型呢?
返回顶部
顶部