我有以下现有的数据库模式,我想使用 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;
}
我遗漏了列名此处实体的属性和其他属性。
然而它并没有完全按预期工作。如果我不指定mappedBy属性为用户.用户数据,hibernate会自动创建一个表USERS_USERS_USERDATA,但据我所见并没有使用它。但是它确实使用了我为Userdata class.
由于我对 Java 和 hibernate 也很陌生,因此目前我所做的测试就是查看 hibernate 在保留一些示例条目时创建的数据库模式。
结果,我完全不知道我这样做是否正确。我阅读了 hibernate 文档和相当多的 Google 结果,但它们似乎都没有处理我想要做的事情(带有“子类”的复合键和它们自己的主键)。
The mappedBy
属性在每个双向关联的一侧是强制性的。当关联是一对多时,mappedBy
属性被放置在一侧(即在User
's userdata
您的案例中的字段)。
这是因为当关联是双向的时,关联的一侧始终是另一侧的反面,因此无需两次告诉 Hibernate 关联的映射方式(即使用哪个连接列或连接表)。
如果您准备好重新创建架构,我会做得正确(而且更容易),并在 users_userdata 中使用代理自动生成的键而不是复合键。在应用程序的所有层中,这将更容易处理。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)