如何制作复合主键(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
即花费(由上述自动生成)userID
从user
实体和roleID
从roles
实体。现在,我需要将生成的表(user_roles
)中的这两列用作复合主键。
回答:
您已经在如何按照自己的要求做一些很好的答案。
作为参考,让我仅提及在Hibernate中执行此操作的推荐方法,该方法是使用代理键作为主键,并将业务键标记为NaturalId:
尽管我们建议使用代理键作为主键,但您应尝试识别所有实体的自然键。自然键是唯一或非空的属性或属性组合。它也是不可变的。在元素内映射自然键的属性。Hibernate将生成必要的唯一键和可为空性约束,因此,您的映射将更具自记录性。
建议您实现equals()和hashCode()来比较实体的自然键属性。
在代码中,使用批注,如下所示:
@Entitypublic class UserRole {
@Id
@GeneratedValue
private long id;
@NaturalId
private User user;
@NaturalId
private Role role;
}
使用此功能将为您节省很多麻烦,因为您会发现何时经常需要引用/映射组成的主键。
我发现这很困难,最后只是放弃了与Hibernate的战斗,而是决定顺其自然。我完全理解,在您的情况下这可能是不可能的,因为您可能正在处理旧版软件或依赖项,但是我只想提及它以供将来参考。(
如果您不能使用它,也许其他人可以使用 !)
以上是 如何制作复合主键(java持久性注释) 的全部内容, 来源链接: utcz.com/qa/412944.html