加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

在Xml映射中使用Hibernate设置创建和更新时间

发布时间:2020-12-16 05:34:59 所属栏目:百科 来源:网络整理
导读:我正在使用Hibernate和Xml映射.我有一个实体,它有两个字段creationDate和updateDate,类型为timestamp,当实体被持久化和更新时,必须填充当前的UTC时间. 我知道@PrePersist和@PreUpdate注释的存在,但我不知道如何在我的Xml映射中使用它们的等价物. 再一次,我想
我正在使用Hibernate和Xml映射.我有一个实体,它有两个字段creationDate和updateDate,类型为timestamp,当实体被持久化和更新时,必须填充当前的UTC时间.
我知道@PrePersist和@PreUpdate注释的存在,但我不知道如何在我的Xml映射中使用它们的等价物.

再一次,我想知道Hibernate是否以某种方式支持本地更新和创建时间设置.

谢谢

I know about the existence of the @PrePersist and @PreUpdate annotations,but i don’t know how to use their equivalent in my Xml mappings.

Hibernate3 event architecture提供了相同的功能,您可以为PreInsertEvent,PreUpdateEvent或SaveOrUpdateEvent(请参阅org.hibernate.event包以获取完整列表)注册侦听器,以设置和更新创建/更新日期.

另一种方法是使用interceptor,Session-scoped或SessionFactory-scoped,并在onSave(…)中设置createDate和updateDate,更新onFlushDirty(…)中的updateDate.

更新:我将在下面留下我的原始建议,但我认为正确的方法(应该是我最初的答案)是使用拦截器或事件架构.

您可以使用timestamp的generated属性分别获取插入时和插入和更新时数据库生成的creationDate和updateDate:

<class name="MyEntity" table="MY_ENTITY">
  <id .../>
  <timestamp name="createDate" generated="insert" ... />
  <timestamp name="updateDate" generated="always" ... />
  ...
</class>

有关详细信息,请参阅generated properties部分.

选项1

看来时间戳不支持generatead,所以我的建议不起作用.然而,在仔细阅读文档之后,我的理解是时间戳是版本控制的替代方案,我认为它不适合像createDate和updateDate这样的字段(它可能适用于后者,但不是时间戳的用途) ).

所以我实际上仍然会使用generated properties而不是simple properties而不是时间戳:

<class name="MyEntity" table="MY_ENTITY">
  <id .../>
  <property name="createDate" update="false" insert="false" generated="insert" ... />
  <property name="updateDate" update="false" insert="false" generated="always" ... />
  ...
</class>

在数据库级别,这将需要使用updateDate列的触发器.对于createDate列,使用current_timestamp等默认值可以很好地工作.但触发器可能不需要……

选项2

为避免触发选项1,一种变体是使用updateDate进行版本控制(从而将其映射为时间戳):

<class name="MyEntity" table="MY_ENTITY">
  <id .../>
  <timestamp name="updateDate" ... />
  <property name="createDate" update="false" insert="false" generated="insert" ... />
  ...
</class>

与createDate的选项1相同,使用数据库级别的默认值.

选项3

看到这个答案的顶部……

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读