繁体   English   中英

JPA复合键@OneToMany

[英]JPA composite key @OneToMany

我有以下现有的 DB 模式,我想用 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 在保留一些示例条目时创建的 DB 模式。

结果,我完全不知道我是否以正确的方式做这件事。 我阅读了 hibernate 文档和相当多的 Google 结果,但它们似乎都没有处理我想要做的事情(带有“子类”的复合键和它们自己的主键)。

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

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM