牛骨文教育服务平台(让学习变的简单)
博文笔记

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

创建时间:2013-08-12 投稿人: 浏览次数:1502
    在一个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。
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。