OID映射对象标识符
OID存在的意义
关系型数据库通过主键来区分同一张表的不同数据,java语言使用内存地址来区分同一类的不同对象,hibernate则使用OID来同一两者之间的矛盾,在运行时,hibernate通过OID来维持java对象和数据库表中记录的对应关系。
OID的配置
在hibernate映射文件中配置,使用<id>元素来设置对象标识符
<id name="id" type="java.lang.Integer">
<column name="id"/>
<generator class="increment"/>
</id>
<generator>子元素来设定标识符生成器,标识符生成器的接口为org.hibernate.id.IdentifierGenerator接口,以及提供了几种内置的实现
- increment Hibernate以递增的方式赋值 先查该表的id最大值,再加一 存在并发问题
- identity 由底层数据库生成,需要把主键设置为自增的(需要底层数据库支持自增 如DB2、Mysql、SQL SERVER)
- sequence 底层数据库序列生成(需要底层数据库支持序列 如Oracle、DB2、PostgreSQL)
- hilo 由hibernate按照一种high/low算法生成,hibernate把特定表的字段最为high值。默认为hibernate_unique_key表的next_hi字段 注意:hilo的方式需要在单独的事务中处理,不使用session对象的当前数据库连接和事务,而是单独的在一个新的数据库连接中创建新的事务,与spring结合时以及配置数据源时注意不可使用该方式生成
- native 根据底层数据库对自动生成主键的支持能力,来选择identity,sequence或hilo生成器
- uuid.hex hibernate采用128位的UUID生成
- assigned 由java程序负责生成
- select 由数据库中的触发器来生成
- foreign 用另一个关联对象的标识符来作为当前对象的标识符,主要用于一对一关联关系
复合主键的配置
复合主键的配置使用<composite-id>
<composite-id>
<key-property name="name" column="name" type="java.lang.String"/>
<key-property name="companyId" column="company_id" type="java.lang.Long"/>
</composite-id>
注意在使用复合主键时,需要定义version版本控制属性,用来区分临时对象和游离对象,判断是保存还是更新
<!-- 表示当对象的version对象为null时为游离对象,还没有被保存过 -->
<version name="version" column="version" unsaved-value="null"/>
由于本身的博客百度没有收录,博客地址http://zhhll.icu
网友评论