hibernate基础记录(2)

hibernate的映射文件提荣了如下主键生成机制映射:

 

1,Assigned 主键由应用逻辑产生,数据交由hibernate保存时,主键值已经设置完毕无需hibernate干预。

 

2,hilo 通过hi/lo算法实现的逐渐生成机制,需要额外的数据库表保存主键生成历史状态。

 

3,seqhilo  与hilo类似,通过hi/lo算法实现的主键生成机制,只是主键历史状态保存在Sequence中,适用于支持Sequence的数据库,例如Oracle

 

4,increment  主键按数字顺序递增,此方式的实现机制为再当前的应用实例中维持一个变量,以保存当前的最大值,之后每次需要生成主键的时候将此值加1作为主键。问题在于再多个实例同时访问一个数据库会产生重复主键,所以避免一个数据库有多个实力访问。请慎用。

 

5,identity 采用数据库自身生成机制。

 

6,Sequence 采用数据库提供的Sequence机制

 

7,由hibernate自动根据数据库适配器中的定义,采用identity,hilo,Sequence中的其一。

 

8,uuid.hex  有hibernate基于128位的唯一值产生算法,根据当前设配ip,time,jvm启动时间,内部自增量等4个参数生成十六进制数值,作为主键。

 

9,uuid.hex 和8类似。只是生成的主键没有进行编码。

 

10,foreign 使用外部表的字段作为主键。

 

11,select  对于使用触发器生成主键的遗留机制。

你可能感兴趣的:(jvm,oracle,算法,Hibernate)