如何将多个字段指定为实体的主键(使用JPA)

she*_*aei 7 java orm jpa

可以通过在JPA中使用@Id注释为其类指定主键.我的问题是如果一个人不希望在他的表中有一个自动生成的密钥并使用字段(可能不止一个)作为主键.

假设我们有一个SSN,NATIONALITY和NAME的人员表.SSN定义为他所在国家/地区识别出的人数.因此,我们可能在两个不同的国家有两个人数相同的人.该表的主键可以是SSN + NATIONALITY.有没有办法使用JPA映射这两个字段并将其映射到对象?或者它是创建自动生成的id并使用@Id注释的唯一方法

CREATE TABLE PERSON (
     SSN   INT,
     NATIONALITY VARCHAR,
     NAME VARCHAR
  )
Run Code Online (Sandbox Code Playgroud)

mic*_*hal 11

对的,这是可能的.复合主键由多个主键字段组成.每个主键字段必须是JPA类型支持的字段之一.对于你的桌子,你有:

@Entity @IdClass(PersonId.class)
public class Person {
    @Id int ssn;
    @Id String nationality;
     ....
}
Run Code Online (Sandbox Code Playgroud)

对于具有多个密钥的实体,JPA需要定义特殊的ID类.应使用@IdClass注释将此类附加到实体类.

class PersonId {
    int ssn;
    String nationality;
}
Run Code Online (Sandbox Code Playgroud)

ID类反映主键字段,其对象可以表示主键值