当前位置: 首页 > 面试题库 >

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

彭飞虎
2023-03-14
问题内容

如何使表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的战斗,而是决定顺其自然。我完全理解,在您的情况下这可能是不可能的,因为您可能正在处理旧版软件或依赖项,但是我只想提及它以供将来参考。(
如果您不能使用它,也许其他人可以使用 !)



 类似资料:
  • 我有以下表格,如何将它们映射到JPA实体: 事件表与会议表具有一对多的关系。我如何在JPA中映射这种双向关系?

  • 我希望即使服务器重新启动,也能保持一个具有固定id的模式。 是否可以在模式注册表中保存模式,以便在服务器崩溃后使用相同的id? 否则,是否有可能在模式注册表服务器启动时用固定的id硬编码一个模式?

  • 问题内容: 我正在使用 现在,由于Cookie无法实现可序列化,因此我无法序列化该List。 编辑:(指定了我的目标,不仅是问题) 我的目标是将DefaultHttpClient与持久性cookie一起使用。 有经验的人可以带领我走上正确的道路吗?我可能还没有发现另一种最佳实践… 问题答案: 创建您自己的类,然后在构造过程中复制属性。像这样: 确保所有属性本身也可序列化。除了基元之外,该类本身例如

  • 问题内容: 我正在设计一个数据库,该数据库将用于存储来自许多不同来源的数据。我存储的实例由原始来源分配了唯一的ID。我存储的每个实例都应包含有关其来源的信息,以及与此来源相关联的ID。 作为示例,请考虑说明该问题的下表: 请注意,尽管每个来源的唯一,但有可能在不同来源中找到相同的来源。 我对关系数据库有一个不错的了解,但是与专家甚至是经验丰富的用户都相去甚远。我在此设计中面临的问题是应该用作主键。

  • 问题内容: 我在这里搜索,但未找到任何类似的主题,因此我发布了一个新问题。 我正在使用现有数据库上的Hibernate。我们不允许更改表的结构和数据。该应用程序正在从数据库读取数据,并根据某种逻辑迁移到另一个数据存储。 现在的问题是关于复合PK映射。例如 表A具有复合PK。 表B也有一个复合PK,此复合PK的一部分是A的PK,此处也用作FK。 我尝试了几种方法,但都无济于事。谁能告诉一个有效的Hi

  • 问题内容: 如何使用复合主键作为外键?看来我的尝试无效。 问题答案: 该行: 是错的。您不能那样使用,这只是父表中PK约束的名称。要将复合主键用作外键,您必须向子表中添加相同数量(组成PK)的相同数据类型的列,然后在定义中使用这些列的组合: