Hibernate: Коллекции Коллекций - PullRequest
       5

Hibernate: Коллекции Коллекций

20 голосов
/ 13 февраля 2009

Это проблема, с которой я продолжаю сталкиваться:

Я бы хотел, чтобы Hibernate управлял одной таблицей, представляющей коллекцию коллекций. Например:

  • Карта карт
  • Список комплектов
  • Карта списков

Например, я хотел бы представить это:

class OwningClass {  
    Long entityId;  
    Map<String, List<Element>> mapOfLists;
}

class Element {
    String data_1;
    boolean data_2;
}

как одна таблица:

OWNER (Foreign key to the owner of this element) 
MAP_KEY (varchar(30) )
LIST_INDEX (int)
ELEMENT_DATA_1 (varchar(1020)
ELEMENT_DATA_2 (bit)

Это кажется невозможным без пользовательского кода гибернации, который я не против. Но я надеялся, что у кого-то будет какое-то руководство о том, как должен выглядеть этот пользовательский код.

  • Должен ли я расширить AbstractPersistentCollection?
  • CompositeUserType

Возможно управлять, если несколько таблиц в порядке. но очевидно, что это глупо с точки зрения БД.

1 Ответ

10 голосов
/ 31 июля 2018

Нашел ответ по https://xebia.com/blog/mapping-multimaps-with-hibernate/

Это длинное сообщение в блоге от 11 лет назад. Код ключа:

public class MultiMapType implements UserCollectionType {

public boolean contains(Object collection, Object entity) {
    return ((MultiMap) collection).containsValue(entity);
}

public Iterator getElementsIterator(Object collection) {
    return ((MultiMap) collection).values().iterator();
}

public Object indexOf(Object collection, Object entity) {
    for (Iterator i = ((MultiMap) collection).entrySet().iterator(); i.hasNext();) {
        Map.Entry entry = (Map.Entry) i.next();    
        Collection value = (Collection) entry.getValue();
        if (value.contains(entity)) {
            return entry.getKey();
        }
    }
    return null;
}

public Object instantiate() {
    return new MultiHashMap();
}

public PersistentCollection instantiate(SessionImplementor session, CollectionPersister persister) throws HibernateException {
    return new PersistentMultiMap(session);
}

public PersistentCollection wrap(SessionImplementor session, Object collection) {
    return new PersistentMultiMap(session, (MultiMap) collection);
}

public Object replaceElements(Object original, Object target, CollectionPersister persister, Object owner, Map copyCache, SessionImplementor session) throws HibernateException {

    MultiMap result = (MultiMap) target;
    result.clear();

    Iterator iter = ( (java.util.Map) original ).entrySet().iterator();
    while ( iter.hasNext() ) {
        java.util.Map.Entry me = (java.util.Map.Entry) iter.next();
        Object key = persister.getIndexType().replace( me.getKey(), null, session, owner, copyCache );
        Collection collection = (Collection) me.getValue();
        for (Iterator iterator = collection.iterator(); iterator.hasNext();) {
            Object value = persister.getElementType().replace( iterator.next(), null, session, owner, copyCache );
            result.put(key, value);
        }
    }

    return result;
}

}

Здесь также был разговор: Мультикарта в Hibernate

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...