首页 > 编程语言 > 详细

JPA的主键生成策略 —— SpringDataJPA(四)

时间:2020-04-11 17:48:33      阅读:79      评论:0      收藏:0      [点我收藏+]

  通过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)  
    )

 

JPA的主键生成策略 —— SpringDataJPA(四)

原文:https://www.cnblogs.com/guancangtingbai/p/12680706.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!