如何制作复合主键(java持久性注释)

如何使表user_roles定义两列(userID,roleID)作为组合主键。应该很容易,只是不记得/找不到。

user实体中:

@ManyToMany(fetch = FetchType.LAZY)

@JoinTable(name = "user_roles")

public List<RoleDAO> getRoles() {

return roles;

}

@Id

@GeneratedValue(strategy = GenerationType.AUTO)

public Integer getUserID() {

return userID;

}

roles实体中:

@ManyToMany(fetch = FetchType.LAZY)

@JoinTable(name = "user_roles")

public List<UserDAO> getUsers() {

return users;

}

@Id

@GeneratedValue(strategy = GenerationType.AUTO)

public Integer getRoleID() {

return roleID;

}

谢谢。

** 更多信息

因此,有一个第三表user_roles即花费(由上述自动生成)userIDuser实体和roleIDroles实体。现在,我需要将生成的表(user_roles)中的这两列用作复合主键。

回答:

您已经在如何按照自己的要求做一些很好的答案。

作为参考,让我仅提及在Hibernate中执行此操作的推荐方法,该方法是使用代理键作为主键,并将业务键标记为NaturalId:

尽管我们建议使用代理键作为主键,但您应尝试识别所有实体的自然键。自然键是唯一或非空的属性或属性组合。它也是不可变的。在元素内映射自然键的属性。Hibernate将生成必要的唯一键和可为空性约束,因此,您的映射将更具自记录性。

建议您实现equals()和hashCode()来比较实体的自然键属性。

在代码中,使用批注,如下所示:

@Entity

public class UserRole {

@Id

@GeneratedValue

private long id;

@NaturalId

private User user;

@NaturalId

private Role role;

}

使用此功能将为您节省很多麻烦,因为您会发现何时经常需要引用/映射组成的主键。

我发现这很困难,最后只是放弃了与Hibernate的战斗,而是决定顺其自然。我完全理解,在您的情况下这可能是不可能的,因为您可能正在处理旧版软件或依赖项,但是我只想提及它以供将来参考。(

如果您不能使用它,也许其他人可以使用 !)

以上是 如何制作复合主键(java持久性注释) 的全部内容, 来源链接: utcz.com/qa/412944.html

回到顶部