参见英文答案 >
JPA composite primary key 2个
可以通过在JPA中使用@Id注释为其类指定主键.我的问题是如果一个人不希望在他的表中有一个自动生成的密钥并使用字段(可能不止一个)作为主键.
可以通过在JPA中使用@Id注释为其类指定主键.我的问题是如果一个人不希望在他的表中有一个自动生成的密钥并使用字段(可能不止一个)作为主键.
假设我们有一个SSN,NATIONALITY和NAME的人员表. SSN被定义为在其国家中识别出某个人的号码.因此,我们可能在两个不同的国家有两个人数相同的人.该表的主键可以是SSN NATIONALITY.有没有办法使用JPA映射这两个字段并将其映射到对象?或者它是创建自动生成的id并使用@Id注释的唯一方法
CREATE TABLE PERSON ( SSN INT,NATIONALITY VARCHAR,NAME VARCHAR )
解决方法
对的,这是可能的.复合主键由多个主键字段组成.每个主键字段必须是JPA类型支持的字段之一.
对于你的桌子,你有:
对于你的桌子,你有:
@Entity @IdClass(PersonId.class) public class Person { @Id int ssn; @Id String nationality; .... }
对于具有多个密钥的实体,JPA需要定义特殊的ID类.应使用@IdClass注释将此类附加到实体类.
class PersonId { int ssn; String nationality; }
ID类反映主键字段,其对象可以表示主键值