侧边栏壁纸
博主头像
张种恩的技术小栈博主等级

行动起来,活在当下

  • 累计撰写 748 篇文章
  • 累计创建 65 个标签
  • 累计收到 39 条评论

目 录CONTENT

文章目录

JPA(3)之JPA中的主键生成策略

zze
zze
2019-10-19 / 0 评论 / 0 点赞 / 490 阅读 / 3204 字

不定期更新相关视频,抖音点击左上角加号后扫一扫右方侧边栏二维码关注我~正在更新《Shell其实很简单》系列

JPA 是通过 annotation(注解)来映射 hibernate 实体的,基于 annotation 的 hibernate 主键标识为 @Id, 其生成规则由 @GeneratedValue设定。这里的 @id@GeneratedValue 都是 JPA 的标准用法。
JPA 提供的四种标准用法为 TABLE、SEQUENCE、IDENTITY、AUTO。
具体说明如下:

IDENTITY

主键由数据库自动生成(主要是自动增长型)。
用法:

@Id  
@GeneratedValue(strategy = GenerationType.IDENTITY) 
private Long custId;

SEQUENCE

根据底层数据库的序列来生成主键,条件是数据库支持序列。
用法:

@Id  
@GeneratedValue(strategy = GenerationType.SEQUENCE,generator="payablemoney_seq")  
@SequenceGenerator(name="payablemoney_seq", sequenceName="seq_payment")  
private Long custId;

@SequenceGenerator 源码中的定义:

@Target({TYPE, METHOD, FIELD})   
@Retention(RUNTIME)  
public @interface SequenceGenerator {  
   //表示该表主键生成策略的名称,它被引用在@GeneratedValue中设置的“generator”值中
   String name();  
   //属性表示生成策略用到的数据库序列名称。
   String sequenceName() default "";  
   //表示主键初识值,默认为0
   int initialValue() default 0;  
   //表示每次主键值增加的大小,例如设置1,则表示每次插入新记录后自动加1,默认为50
   int allocationSize() default 50;  
}

AUTO

主键由程序控制。
用法:

@Id  
@GeneratedValue(strategy = GenerationType.AUTO)  
private Long custId;

TABLE

使用一个特定的数据库表格来保存主键。
用法:

@Id  
@GeneratedValue(strategy = GenerationType.TABLE, generator="payablemoney_gen")  
@TableGenerator(name = "pk_gen",  
    table="tb_generator",  
    pkColumnName="gen_name",  
    valueColumnName="gen_value",  
    pkColumnValue="PAYABLEMOENY_PK",  
    allocationSize=1  
) 
private Long custId;

@TableGenerator 的定义:

@Target({TYPE, METHOD, FIELD})   
@Retention(RUNTIME)  
public @interface TableGenerator {  
  //表示该表主键生成策略的名称,它被引用在@GeneratedValue中设置的“generator”值中
  String name();  
  //表示表生成策略所持久化的表名,例如,这里表使用的是数据库中的“tb_generator”。
  String table() default "";  
  //catalog和schema具体指定表所在的目录名或是数据库名
  String catalog() default "";  
  String schema() default "";  
  //属性的值表示在持久化表中,该主键生成策略所对应键值的名称。例如在“tb_generator”中将“gen_name”作为主键的键值
  String pkColumnName() default "";  
  //属性的值表示在持久化表中,该主键当前所生成的值,它的值将会随着每次创建累加。例如,在“tb_generator”中将“gen_value”作为主键的值 
  String valueColumnName() default "";  
  //属性的值表示在持久化表中,该生成策略所对应的主键。例如在“tb_generator”表中,将“gen_name”的值为“CUSTOMER_PK”。 
  String pkColumnValue() default "";  
  //表示主键初识值,默认为0。 
  int initialValue() default 0;  
  //表示每次主键值增加的大小,例如设置成1,则表示每次创建新记录后自动加1,默认为50。
  int allocationSize() default 50;  
  UniqueConstraint[] uniqueConstraints() default {};  
} 

这里应用表 tb_generator,定义为 :

CREATE TABLE  tb_generator (  
  id NUMBER NOT NULL,  
  gen_name VARCHAR2(255) NOT NULL,  
  gen_value NUMBER NOT NULL,  
  PRIMARY KEY(id)  
)
0
JPA

评论区