簡體   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