我有一个实体。有时我需要这个对象也包含一些值,称之为“深度”。查询可能看起来像'select b.id, b.name, b..., count(c.id) as depth from Entity b, CEntity c where ...'
。所以我创建了扩展实体的非HibernateEntity类。然后,上面写的查询结果被完美地存储为非hibEntity列表,该列表由Entity的所有字段(当它们被扩展时)和属性“depth”组成。我通过设置aliastoBean结果转换器:.setResultTransformer(Transformers.aliasToBean(NHEntity.class)).
但是,指定所有所需字段的所有别名既烦人又不方便。
然后,如果我想将这个对象中的一个保存到db-session.saveOrUpdate((Enity)nHibEntity)
-有一个关于nhibentity不是hibernate entity的异常。
我听说过将“entity”作为字段存储在nonhibentity中(聚合,而不是继承)。但这似乎也很不方便。
你怎么认为?什么是合适的解决方案?
最佳答案
列映射可能适合您的需要。我先试试这个。
如果这会像您担心的那样导致性能问题,那么您可能会尝试仅在子表中使用此字段映射类层次结构,并将两者映射到同一个表。但不确定这是否真的有效…
最后一种方法是,使用一个未映射的类,但将实体作为另一个类聚合中的字段,而不是像您所说的继承,并确保有一种方法可以从未映射的实体中检索映射的实体,以便保存。将其设为Formula是明智的,这样它既是子类又是聚合,并且您可以继续忽略代码中的许多区别。
但是,对于未映射的子类和/或聚合,您必须拉出实体才能保存。