5.1.7. 版本(version)(可选)

<version>元素是可选的,表明表中包含附带版本信息的数据。 这在你准备使用 长事务(long transactions)的时候特别有用。(见后)

  1. <version
  2. column="version_column"
  3. name="propertyName"
  4. type="typename"
  5. access="field|property|ClassName"
  6. unsaved-value="null|negative|undefined"
  7. generated="never|always"
  8. insert="true|false"
  9. node="element-name|@attribute-name|element/@attribute|."
  10. />
1column (可选 - 默认为属性名): 指定持有版本号的字段名。
2name: 持久化类的属性名。
3type (可选 - 默认是 integer): 版本号的类型。
4access (可选 - 默认是 property): Hibernate用于访问属性值的策略。
5unsaved-value (可选 - 默认是undefined): 用于标明某个实例时刚刚被实例化的(尚未保存)版本属性值,依靠这个值就可以把这种情况 和已经在先前的session中保存或装载的脱管(detached)实例区分开来。 (undefined指明应被使用的标识属性值。)
6generated (可选 - 默认是 never): 表明此版本属性值是否实际上是由数据库生成的。请参阅第 5.6 节 “数据库生成属性(Generated Properties)”部分的讨论。
7insert (可选 - 默认是 true): 表明此版本列应该包含在SQL插入语句中。只有当数据库字段有默认值0的时候,才可以设置为false

版本号必须是以下类型:long, integer, short, timestamp或者calendar

一个脱管(detached)实例的version或timestamp属性不能为空(null),因为Hibernate不管 unsaved-value被指定为何种策略,它将任何属性为空的version或timestamp 实例看作为瞬时(transient)实例。 避免Hibernate中的传递重附(transitive reattachment)问题的一个简单方法是 定义一个不能为空的version或timestamp属性,特别是在人们使用程序分配的标识符(assigned identifiers) 或复合主键时非常有用!