通过annotation(注解)来映射hibernate实体的,基于annotation的hibernate主键标识为@Id, 其生成规则由@GeneratedValue设定的.这里的@id和@GeneratedValue都是JPA的标准用法。
JPA提供的四种标准用法为TABLE,SEQUENCE,IDENTITY,AUTO。
具体说明如下:
IDENTITY:主键由数据库(Mysql)自动生成(主要是自动增长型)
用法:
@Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long custId;
SEQUENCE:根据底层数据库的序列来生成主键,条件是数据库(Oracle)支持序列。
用法:
@Id @GeneratedValue(strategy = GenerationType.SEQUENCE,generator="payablemoney_seq") @SequenceGenerator(name="payablemoney_seq", sequenceName="seq_payment") private Long custId;
1 //@SequenceGenerator源码中的定义 2 @Target({TYPE, METHOD, FIELD}) 3 @Retention(RUNTIME) 4 public @interface SequenceGenerator { 5 //表示该表主键生成策略的名称,它被引用在@GeneratedValue中设置的“generator”值中 6 String name(); 7 //属性表示生成策略用到的数据库序列名称。 8 String sequenceName() default ""; 9 //表示主键初识值,默认为0 10 int initialValue() default 0; 11 //表示每次主键值增加的大小,例如设置1,则表示每次插入新记录后自动加1,默认为50 12 int allocationSize() default 50; 13 }
AUTO:主键由程序控制
用法:
@Id @GeneratedValue(strategy = GenerationType.AUTO) private Long custId;
TABLE:使用一个特定的数据库表格来保存主键
用法:
1 @Id 2 @GeneratedValue(strategy = GenerationType.TABLE, generator="payablemoney_gen") 3 @TableGenerator(name = "pk_gen", 4 table="tb_generator", 5 pkColumnName="gen_name", 6 valueColumnName="gen_value", 7 pkColumnValue="PAYABLEMOENY_PK", 8 allocationSize=1 9 ) 10 private Long custId; 11 12 13 //@TableGenerator的定义: 14 @Target({TYPE, METHOD, FIELD}) 15 @Retention(RUNTIME) 16 public @interface TableGenerator { 17 //表示该表主键生成策略的名称,它被引用在@GeneratedValue中设置的“generator”值中 18 String name(); 19 //表示表生成策略所持久化的表名,例如,这里表使用的是数据库中的“tb_generator”。 20 String table() default ""; 21 //catalog和schema具体指定表所在的目录名或是数据库名 22 String catalog() default ""; 23 String schema() default ""; 24 //属性的值表示在持久化表中,该主键生成策略所对应键值的名称。例如在“tb_generator”中将“gen_name”作为主键的键值 25 String pkColumnName() default ""; 26 //属性的值表示在持久化表中,该主键当前所生成的值,它的值将会随着每次创建累加。例如,在“tb_generator”中将“gen_value”作为主键的值 27 String valueColumnName() default ""; 28 //属性的值表示在持久化表中,该生成策略所对应的主键。例如在“tb_generator”表中,将“gen_name”的值为“CUSTOMER_PK”。 29 String pkColumnValue() default ""; 30 //表示主键初识值,默认为0。 31 int initialValue() default 0; 32 //表示每次主键值增加的大小,例如设置成1,则表示每次创建新记录后自动加1,默认为50。 33 int allocationSize() default 50; 34 UniqueConstraint[] uniqueConstraints() default {}; 35 } 36 37 //这里应用表tb_generator,定义为 : 38 CREATE TABLE tb_generator ( 39 id NUMBER NOT NULL, 40 gen_name VARCHAR2(255) NOT NULL, 41 gen_value NUMBER NOT NULL, 42 PRIMARY KEY(id) 43 )