zoukankan      html  css  js  c++  java
  • @GeneratedValue 四种标准用法为TABLE,SEQUENCE,IDENTITY,AUTO

    一、JPA通用策略生成器 
    JPA提供四种标准用法,由@GeneratedValue的源代码:

        @Target({METHOD,FIELD})    
        @Retention(RUNTIME)    
        public @interface GeneratedValue{    
            GenerationType strategy() default AUTO;    
            String generator() default "";    
        }   

    其中GenerationType: 

    public enum GenerationType{    
        TABLE,    
        SEQUENCE,    
        IDENTITY,    
        AUTO   
    } 

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

    一: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  
    )

    这里应用表tb_generator,定义为 

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

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

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

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

    @TableGenerator的定义:

    @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标记中的用法类似。 

    二:SEQUENCE

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

    @SequenceGenerator定义

    @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。 

    三:IDENTITY 

    @Id  
    @GeneratedValue(strategy = GenerationType.IDENTITY)  

    四:AUTO

    @Id  
    @GeneratedValue(strategy = GenerationType.AUTO)  

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

    @Id  

    跟下面的定义是一样的

    @Id  
    @GeneratedValue(strategy = GenerationType.AUTO)  
  • 相关阅读:
    洛谷P5979 [PA2014]Druzyny
    洛谷P5592 美德的讲坛
    BZOJ4231 回忆树
    Python爬虫〇二———从几个简单的爬虫开始
    Flink实例(115):自定义时间和窗口的操作符(十四)窗口操作符(四)触发器(Triggers) (二)
    商业化数据分析师(三十二):平台商品画像实战项目(三)购物篮分析
    商业化数据分析师(三十一):平台商品画像实战项目(二)如何构建商品画像-- 以移动电源为例
    商业化数据分析师(三十):平台商品画像实战项目(一)简介
    商业化数据分析师(二十九):平台用户画像实战项目(二)如何构建平台用户的用户画像
    商业化数据分析师(二十八):平台用户画像实战项目(一)什么是用户画像体系以及商户用户画像和平台用户画像的区别
  • 原文地址:https://www.cnblogs.com/zsg88/p/8446536.html
Copyright © 2011-2022 走看看