一篇文章掌握JPA的@GeneratedValue

本文详细介绍了JPA中的主键生成策略,包括@TableGenerator、@SequenceGenerator和@GeneratedValue(strategy=GenerationType.AUTO)。同时,文章还讨论了Hibernate特有的主键生成策略,如native、uuid、hilo等,并展示了如何使用@GenericGenerator自定义主键生成策略。
摘要由CSDN通过智能技术生成

一、JPA通用策略生成器  

通过annotation来映射hibernate实体的,基于annotation的hibernate主键标识为@Id,

其生成规则是由@GeneratedValue设定的。这里的@id和@GeneratedValue都是JPA的标准用法。 

JPA提供四种标准用法,由@GeneratedValue的源代码可以明显看出:

 
  1. @Target({METHOD,FIELD})

  2. @Retention(RUNTIME)

  3. public @interface GeneratedValue{

  4. GenerationType strategy() default AUTO;

  5. String generator() default "";

  6. }

其中GenerationType: 

 
  1. public enum GenerationType{

  2. TABLE,

  3. SEQUENCE,

  4. IDENTITY,

  5. AUTO

  6. }


JPA提供的四种标准用法为TABLE,SEQUENCE,IDENTITY,AUTO。 
a,TABLE:使用一个特定的数据库表格来保存主键。  
b,SEQUENCE:根据底层数据库的序列来生成主键,条件是数据库支持序列。  
c,IDENTITY:主键由数据库自动生成(主要是自动增长型)  
d,AUTO:主键由程序控制。  

1、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. )

这里应用表tb_generator,定义为:

 
  1. CREATE TABLE tb_generator (

  2. id NUMBER NOT NULL,

  3. gen_name VARCHAR2(255) NOT NULL,

  4. gen_value NUMBER NOT NULL,

  5. PRIMARY KEY(id)

  6. )

插入纪录,供生成主键使用, 

INSERT INTO tb_generator(id, gen_name, gen_value) VALUES (1,PAYABLEMOENY_PK', 1); 

在主键生成后,这条纪录的value值,按allocationSize递增。 


@TableGenerator的定义: 

 
  1. @Target({TYPE, METHOD, FIELD})

  2. @Retention(RUNTIME)

  3. public @interface TableGenerator {

  4. String name();

  5. String table() default "";

  6. String catalog() default "";

  7. String schema() default "";

  8. String pkColumnName() default "";

  9. String valueColumnName() default "";

  10. String pkColumnValue() default "";

  11. int initialValue() default 0;

  12. int allocationSize() default 50;

  13. UniqueConstraint[] uniqueConstraints() default {};

  14. }

以上属性说明如下:  
name 属性表示该表主键生成策略的名称,它被引用在@GeneratedValue中设置的“generator”值中;  
table 属性表示表生成策略所持久化的表名,例如,这里表使用的是数据库中的“tb_generator”; 
catalog 属性和 schema属性具体指定表所在的目录名或是数据库模式名; 
pkColumnName 属性的值表示在持久化表中,该主键生成策略所对应键值的名称。例如在“tb_generator”中将“gen_name”作为主键的键值; 
valueColumnName 属性的值表示在持久化表中,该主键当前所生成的值,它的值将会随着每次创建累加。例如,在“tb_generator”中将“gen_value”作为主键的值; 
pkColumnValue 属性的值表示在持久化表中,该生成策略所对应的主键。例如在“tb_generator”表中,将“gen_name”的值为“CUSTOMER_PK”; 
initialValue 表示主键初始值,默认为0; 
allocationSize 表示每次主键值增加的大小。例如设置成1ÿ

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值