@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位的字符串,是唯一的值。最通用的,适用于所有数据库。