Hibernate主键策略生成器hibernate提供多种主键生成策略,有点是类似于JPA 有的是hibernate特有:
native : 对于oracle采用sequence 方式,对于 MySql 和sql server采用identity(自增主键生成机制)
native就是将主键的生成工作交由数据库完成
uuid: 采用128位的uuid算法生成主键,uuid被编码为一个32位16进制数字的字符串占用空间大(字符串类型)
示例代码片段:
@Entity
@Table(name="ts_resource")
public class Resource {
@Id
@GeneratedValue(generator="idGenerator")
@GenericGenerator(name="idGenerator", strategy="uuid")
private String id;
对应数据库:varchar2(32)。
sequence : 调用底层数据库的序列来生成主键,要设定序列名 不然hibernate无法找到
increment: 插入数据的时候hibernate会给主键添加一个自增的主键,但是一个hibernate实例就维护一个计数器,所以在多个实例运行的时候不能使用这个方法
foreign: 使用另外一个相关联的对象的主键,通常和<one-to-one>联系起来使用。
guid: 采用数据库底层的guid算法机制。对应MySQl的uuid()函数 SQL Server的newid()函数 Oracle的sys_guid()函数