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 对于使用触发器生成主键的遗留机制。