Hibernate或JPA支持4种不同类型的主键生成器。这些生成器用于在数据库中插入行时生成主键。以下是主键生成器 -
GenerationType.AUTO
GenerationType。身份
GenerationType.SEQUENCE
GenerationType.TABLE
GenerationType。IDENTITY-在identity中,数据库负责自动生成主键。 插入一行而不指定ID的值,然后在插入该行之后,向数据库询问最后生成的ID。Oracle 11g不支持身份键生成器。Oracle 12c支持此功能。
GenerationType。序列-依次,我们首先向数据库询问序列的下一组,然后插入具有返回序列ID的行。
序号 | 键 | GenerationType。身份 | GenerationType.SEQUENCE |
---|---|---|---|
1个 | 基本的 | 数据库负责自动生成主键 | 我们首先要求数据库提供下一个序列集,然后插入带有返回序列ID的行。 |
2 | 性能 | 它比序列键生成器快 | 比身份键生成器慢一点 |
3 | 数据库支持 | Oracle 11g不支持身份键生成器 | Oracle 11g确实支持SEQUENCE键生成器 |
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
Integer id;
String name;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE)
Integer id;
String name;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}