一尘不染

Hibernate:集合的集合

hibernate

我一直遇到这个问题:

我想让hibernate管理一个表示集合集合的表。例如:

  • 地图地图
  • 套装清单
  • 清单地图

例如,我希望能够代表这一点:

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

类元素{
    字符串data_1;
    布尔数据_2;
}

作为一个表:

所有者(此元素所有者的外键) 
MAP_KEY(varchar(30))
LIST_INDEX(int)
ELEMENT_DATA_1(varchar(1020)
ELEMENT_DATA_2(位)

没有自定义的hibernate代码似乎是不可能的,我不介意。但是我希望有人对自定义代码的外观有所指导。

  • 我应该扩展AbstractPersistentCollection吗?
  • CompositeUserType?

可以管理多个表是否正常,但是从数据库角度来看显然很obviously脚。


阅读 253

收藏
2020-06-20

共1个答案

一尘不染

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;
}

}

2020-06-20