JPA注解自动生成主键+UUID

时间:2021-09-18 06:01:32
@GeneratedValue : 这个注解用于自动生成主键,源码如下:
@Target({ElementType.METHOD, ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
public @interface GeneratedValue {
    GenerationType strategy() default GenerationType.AUTO;

    String generator() default "";
}

 一、主键的生产策略由属性  strategy 指定,值由一个枚举 GenerationType 来指定,默认是 AUTO 。

  1、AUTO 自动选择一个最适合底层数据库的主键生成策略,如MySQL会自动对应auto increment。

    这个是默认选项,即如果只写 @GeneratedValue,等价于@GeneratedValue(strategy=GenerationType.AUTO)。

  2、IDENTITY 表自增长字段,Oracle不支持这种方式。--用于支持主键自增长的数据库,如mysql,sqlserver

  3、SEQUENCE 通过序列产生主键,这个一般用于 Oracle。

  4、TABLE 通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植。不同的JPA实现商生成的表名是不同的,如 OpenJPA生成openjpa_sequence_table表,Hibernate生成一个hibernate_sequences表,而TopLink则生成sequence表。这些表都具有一个序列名和对应值两个字段,如SEQ_NAME和SEQ_COUNT。

  在我们的应用中,一般选用  @GeneratedValue 这种方式,自动选择主键生成策略,以适应不同的数据库移植。

  

二、generator 这个属性

我用的sqlserver,如何用自动生产uuid作为表主键???

    @Id
    @GenericGenerator(name = "user-uuid", strategy = "uuid")
    @GeneratedValue(generator = "user-uuid")
    @Column(name = "id", nullable = false, length = 64)
    public String getId() {
        return id;
    }

 @GenericGenerator注解是hibernate的注解,声明一个主键生成器;

    @GeneratedValue 注解的 generator属性指定主键生成器


这是我在项目中使用的一种方式,生成32位的字符串,是唯一的值。最通用的,适用于所有数据库。