5.1.7. 版本(version)(可选)
<version>
元素是可选的,表明表中包含附带版本信息的数据。 这在你准备使用 长事务(long transactions)的时候特别有用。(见后)
<version
column="version_column"
name="propertyName"
type="typename"
access="field|property|ClassName"
unsaved-value="null|negative|undefined"
generated="never|always"
insert="true|false"
node="element-name|@attribute-name|element/@attribute|."
/>
column (可选 - 默认为属性名): 指定持有版本号的字段名。 |
|
---|---|
name : 持久化类的属性名。 |
|
type (可选 - 默认是 integer ): 版本号的类型。 |
|
access (可选 - 默认是 property ): Hibernate用于访问属性值的策略。 |
|
unsaved-value (可选 - 默认是undefined ): 用于标明某个实例时刚刚被实例化的(尚未保存)版本属性值,依靠这个值就可以把这种情况 和已经在先前的session中保存或装载的脱管(detached)实例区分开来。 (undefined 指明应被使用的标识属性值。) |
|
generated (可选 - 默认是 never ): 表明此版本属性值是否实际上是由数据库生成的。请参阅第 5.6 节 “数据库生成属性(Generated Properties)”部分的讨论。 |
|
insert (可选 - 默认是 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) 或复合主键时非常有用!