我知道@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
看到这个答案的顶部……