• JPA中的主键生成策略


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

    总结:https://www.cnblogs.com/xiaohouzai/p/8989378.html

  • 相关阅读:
    [LeetCode] 1267. Count Servers that Communicate 统计参与通信的服务器
    [LeetCode] 1292. Maximum Side Length of a Square with Sum Less than or Equal to Threshold 元素和小于等于阈值的正方形的最大边长
    上周热点回顾(4.114.17)
    上周热点回顾(4.44.10)
    [转]mysql 中间件MyCAT
    mysql 中间件MyCAT
    [转]mysql分布式分片篇
    [转]到底什么是“信创”
    [转]MySQL Cluste(入门篇)—分布式数据库集群搭建
    springboot~jackson和redis日期序列化
  • 原文地址:https://www.cnblogs.com/116970u/p/11589217.html
Copyright © 2020-2023  润新知