Sto provando a configurare un semplice pattern EAV nella mia app Web utilizzando Java/Spring MVC e Hibernate. Non riesco a capire la magia dietro la configurazione XML di ibernazione per questo scenario.Implementazione di pattern EAV con Hibernate per utente -> Relazione impostazioni
mio database tabella "SETUP" ha tre colonne:
- id_utente (FK)
- setup_item
- setup_value
La chiave composta banca dati è costituito da user_id | setup_item
Ecco la classe 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;
}
}
Il mio problema con l'installazione Hibernate, è che io non riesco a capire come tracciare il fatto che una chiave esterna e la chiave di una mappa costruirà la chiave composita della tabella ... ciò è dovuto alla mancanza di esperienza nell'utilizzo di Hibernate. Ecco il mio primo tentativo di ottenere questo al lavoro:
<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>
Tutta la comprensione di come mappare correttamente questo scenario comune sarebbe apprezzato!
@Trevor Benvenuto, ma se vedi una risposta utile, in suvota, grazie! –