zoukankan      html  css  js  c++  java
  • 【01-06】JPA 全局单一主键

    建一张主键表

        @Override
        public boolean equals(Object o) {
            return (o == this || (o instanceof AbstractEntity && uid().equals(((AbstractEntity)o).uid())));
        }
    
    CREATE TABLE  tb_generator (
    
      id int(20) unsigned NOT NULL auto_increment,
    
      gen_name varchar(255) NOT NULL,
    
      gen_value int(20) NOT NULL,
    
      PRIMARY KEY  (id)
    
    )
    INSERT INTO tb_generator ( gen_name ,gen_value ) VALUES ( 'CUSTOMER_PK',1);
    
    INSERT INTO tb_generator ( gen_name ,gen_value ) VALUES ( 'CONTACT_PK',100);
    

    指定全局主键

    
          @Id
    
             @GeneratedValue(strategy = GenerationType.TABLE,generator="customer_gen")
    
             @TableGenerator(name = "customer_gen",
    
                                table="tb_generator",
    
                                pkColumnName="gen_name",
    
                                valueColumnName="gen_value",
    
                                pkColumnValue="CUSTOMER_PK",
    
                                allocationSize=1
    
             )
    
    
    

    JPA 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标记中的用法类似
    */
    
    
  • 相关阅读:
    请求转发和请求重定向的区别
    查看电脑连过的WiFi密码
    linux mysql不能远程登录
    map的遍历方法
    ________________springbootのMybatis
    ________________springbootのTest
    ________________springbootの自定义starter
    ________________springbootのAOP
    ________________springbootのjdbc、事物
    ________________初学springboot14
  • 原文地址:https://www.cnblogs.com/achievec/p/6254584.html
Copyright © 2011-2022 走看看