Java/Spring MVC と Hibernate を使用して、Web アプリで単純な EAV パターンをセットアップしようとしています。このシナリオの休止状態の XML セットアップの背後にある魔法を理解できないようです。
私のデータベース テーブル "SETUP" には 3 つの列があります。
- ユーザー ID (外部キー)
- setup_item
- セットアップ値
データベース複合キーは、user_id |で構成されます。setup_item
Setup.java クラスは次のとおりです。
public class Setup implements CommonFormElements, Serializable {
private Map data = new HashMap();
private String saveAction;
private Integer speciesNamingList;
private User user;
Logger log = LoggerFactory.getLogger(Setup.class);
public String getSaveAction() {
return saveAction;
}
public void setSaveAction(String action) {
this.saveAction = action;
}
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
public Integer getSpeciesNamingList() {
return speciesNamingList;
}
public void setSpeciesNamingList(Integer speciesNamingList) {
this.speciesNamingList = speciesNamingList;
}
public Map getData() {
return data;
}
public void setData(Map data) {
this.data = data;
}
}
Hibernate セットアップに関する私の問題は、外部キーとマップのキーがテーブルの複合キーを構築するという事実をマップする方法を理解できないように見えることです...これは不足によるものですHibernate の使用経験。これを機能させるための私の最初の試みは次のとおりです。
<composite-id>
<key-many-to-one foreign-key="id" name="user" column="user_id" class="Business.User">
<meta attribute="use-in-equals">true</meta>
</key-many-to-one>
</composite-id>
<map lazy="false" name="data" table="setup">
<key column="user_id" property-ref="user"/>
<composite-map-key class="Command.Setup">
<key-property name="data" column="setup_item" type="string"/>
</composite-map-key>
<element column="setup_value" not-null="true" type="string"/>
</map>
この一般的なシナリオを適切にマッピングする方法についての洞察をいただければ幸いです。