基于annotation的hibernate主键生成策略

本文介绍了JPA中四种主键生成策略:TABLE、SEQUENCE、IDENTITY与AUTO,并详细解释了每种策略的配置方法及应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里讨论代理主键,业务主键(比如说复合键等)这里不讨论。
一、JPA通用策略生成器
通过annotation来映射hibernate实体的,基于annotation的hibernate主键标识为@Id,
其生成规则由@GeneratedValue设定的.这里的@id和@GeneratedValue都是JPA的标准用法,
JPA提供四种标准用法,由@GeneratedValue的源代码可以明显看出.

Java代码 复制代码
  1. @Target({METHOD,FIELD})     
  2.     @Retention(RUNTIME)     
  3.     public @interface GeneratedValue{     
  4.          GenerationType strategy() default AUTO;     
  5.          String generator() default "";     
  6.      }   
Java代码 复制代码
  1. @Target({METHOD,FIELD})     
  2.     @Retention(RUNTIME)     
  3.     public @interface GeneratedValue{     
  4.          GenerationType strategy() default AUTO;     
  5.          String generator() default "";     
  6.      }   
@Target({METHOD,FIELD})  
    @Retention(RUNTIME)  
    public @interface GeneratedValue{  
        GenerationType strategy() default AUTO;  
        String generator() default "";  
    }



其中GenerationType:

Java代码 复制代码
  1. public enum GenerationType{     
  2.      TABLE,     
  3.      SEQUENCE,     
  4.      IDENTITY,     
  5.      AUTO   
  6. }  
Java代码 复制代码
  1. public enum GenerationType{     
  2.      TABLE,     
  3.      SEQUENCE,     
  4.      IDENTITY,     
  5.      AUTO   
  6. }  
public enum GenerationType{  
    TABLE,  
    SEQUENCE,  
    IDENTITY,  
    AUTO 
}



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

1、TABLE

Java代码 复制代码
  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. )  
Java代码 复制代码
  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. )  
@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
)



这里应用表tb_generator,定义为

Sql代码 复制代码
  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. )  
Sql代码 复制代码
  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. )  
CREATE TABLE  tb_generator (
  id NUMBER NOT NULL,
  gen_name VARCHAR2(255) NOT NULL,
  gen_value NUMBER NOT NULL,
  PRIMARY KEY(id)
)



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

Sql代码 复制代码
  1. INSERT INTO tb_generator(id, gen_name, gen_value) VALUES (1,PAYABLEMOENY_PK', 1);  
Sql代码 复制代码
  1. INSERT INTO tb_generator(id, gen_name, gen_value) VALUES (1,PAYABLEMOENY_PK', 1);  
INSERT INTO tb_generator(id, gen_name, gen_value) VALUES (1,PAYABLEMOENY_PK', 1);



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


@TableGenerator的定义:

Java代码 复制代码
  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. }  
Java代码 复制代码
  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. }  
@Target({TYPE, METHOD, FIELD}) 
@Retention(RUNTIME)
public @interface TableGenerator {
  String name();
  String table() default "";
  String catalog() default "";
  String schema() default "";
  String pkColumnName() default "";
  String valueColumnName() default "";
  String pkColumnValue() default "";
  int initialValue() default 0;
  int allocationSize() default 50;
  UniqueConstraint[] uniqueConstraints() default {};
}



其中属性说明:
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,默认为50。
UniqueConstraint与@Table标记中的用法类似。

2、SEQUENCE

Java代码 复制代码
  1. @Id  
  2. @GeneratedValue(strategy = GenerationType.SEQUENCE,generator="payablemoney_seq")   
  3. @SequenceGenerator(name="payablemoney_seq", sequenceName="seq_payment")  
Java代码 复制代码
  1. @Id  
  2. @GeneratedValue(strategy = GenerationType.SEQUENCE,generator="payablemoney_seq")   
  3. @SequenceGenerator(name="payablemoney_seq", sequenceName="seq_payment")  
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE,generator="payablemoney_seq")
@SequenceGenerator(name="payablemoney_seq", sequenceName="seq_payment")


@SequenceGenerator定义

Java代码 复制代码
  1. @Target({TYPE, METHOD, FIELD})   
  2. @Retention(RUNTIME)   
  3. public @interface SequenceGenerator {   
  4. String name();   
  5. String sequenceName() default "";   
  6. int initialValue() default 0;   
  7. int allocationSize() default 50;   
  8. }  
Java代码 复制代码
  1. @Target({TYPE, METHOD, FIELD})   
  2. @Retention(RUNTIME)   
  3. public @interface SequenceGenerator {   
  4. String name();   
  5. String sequenceName() default "";   
  6. int initialValue() default 0;   
  7. int allocationSize() default 50;   
  8. }  
@Target({TYPE, METHOD, FIELD}) 
@Retention(RUNTIME)
public @interface SequenceGenerator {
 String name();
 String sequenceName() default "";
 int initialValue() default 0;
 int allocationSize() default 50;
}



name属性表示该表主键生成策略的名称,它被引用在@GeneratedValue中设置的“generator”值中。
sequenceName属性表示生成策略用到的数据库序列名称。
initialValue表示主键初识值,默认为0。
allocationSize表示每次主键值增加的大小,例如设置成1,则表示每次创建新记录后自动加1,默认为50。


3、IDENTITY

Java代码 复制代码
  1. @Id  
  2. @GeneratedValue(strategy = GenerationType.IDENTITY)  
Java代码 复制代码
  1. @Id  
  2. @GeneratedValue(strategy = GenerationType.IDENTITY)  
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)


4、AUTO

Java代码 复制代码
  1. @Id  
  2. @GeneratedValue(strategy = GenerationType.AUTO)  
Java代码 复制代码
  1. @Id  
  2. @GeneratedValue(strategy = GenerationType.AUTO)  
@Id
@GeneratedValue(strategy = GenerationType.AUTO)


在指定主键时,如果不指定主键生成策略,默认为AUTO。

Java代码 复制代码
  1. @Id  
Java代码 复制代码
  1. @Id  



跟下面的定义是一样的。

Java代码 复制代码
  1. @Id  
  2. @GeneratedValue(strategy = GenerationType.AUTO)  
Java代码 复制代码
  1. @Id  
  2. @GeneratedValue(strategy = GenerationType.AUTO)  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值