gpt4 book ai didi

java - JPA 组合键 @OneToMany

转载 作者:行者123 更新时间:2023-12-04 06:12:52 27 4
gpt4 key购买 nike

我有以下现有的数据库模式,我想用 Java 和纯 JPA 注释重新创建它(使用 hibernate 作为提供者,所以 hibernate 特定的注释将作为最后的手段):

CREATE TABLE users (
user_id NUMBER NOT NULL -- pk
);

CREATE TABLE userdata_keys (
userdata_key_id NUMBER NOT NULL, -- pk
key VARCHAR2(128) NOT NULL
);

CREATE TABLE users_userdata (
user_id NUMBER NOT NULL, -- fk users.user_id
userdata_key_id NUMBER NOT NULL, -- fk userdata_keys.userdata_key_id
value VARCHAR2(256)
);

因此我创建了以下类和注释:

class User {
@Id
Long id;
@OneToMany
Set<Userdata> userdata;
}

class UserdataKey {
@Id
Long id;
String key;
}

class Userdata {
String value;
@EmbeddedId
UserdataId userdataId;
}

@Embeddable
class UserdataId {
User user;
UserdataKey userdataKey;
}

我在这里省略了实体的 columnName 属性和其他属性。
然而,它并没有完全按预期工作。 如果我没有为 User.userdata 指定一个 mappedBy 属性,hibernate 将自动创建一个表 USERS_USERS_USERDATA,但据我所知并没有使用它.但是,它确实使用了我为 Userdata 类指定的表。

因为我对 Java 和 hibernate 还是比较陌生,所以我目前所做的测试就是查看 hibernate 在持久化一些示例条目时创建的数据库模式。

因此,我对自己的做法是否正确感到非常困惑。我阅读了 hibernate 文档和相当多的 Google 结果,但它们似乎都没有处理我想做的事情(带有“子类”的复合键和它们自己的主键)。

最佳答案

mappedBy 属性在每个双向关联的其中一侧是强制性的。当关联是一对多时,mappedBy 属性被放置在一侧(即在 Useruserdata 上)你的情况下的字段)。

这是因为当一个关联是双向的时,关联的一侧总是另一侧的反面,所以不需要两次告诉 Hibernate 关联是如何映射的(即使用哪个连接列或连接表)。

如果您准备好重新创建架构,我会做对(并且更容易),并在 users_userdata 中使用代理项自动生成的键而不是复合键。在应用程序的所有层中,这将更容易处理。

关于java - JPA 组合键 @OneToMany,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7569702/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com