gpt4 book ai didi

java - 如何将数据库中计数的属性添加到@Entity 类?

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:17:38 28 4
gpt4 key购买 nike

我有一个实体。有时我需要这个对象也包含一些值,称之为“深度”。查询可能类似于 'select b.id, b.name, b..., count(c.id) as depth from Entity b, CEntity c where ...'。所以我创建了扩展实体的类 NonHibernateEntity。然后上面写的查询结果完美地存储为 NonHibEntity 的列表,它由实体的所有字段(因为它们被扩展)和属性“深度”组成。我通过设置 aliasToBean 结果转换器来实现它:.setResultTransformer(Transformers.aliasToBean(NHEntity.class)).但是,这很烦人且不方便 - 指定所有需要的字段的所有别名。然后,如果我想将此对象之一保存到数据库 - session.saveOrUpdate((Enity)nHibEntity) - 有一个关于 nHibEntity 不是 Hibernate 实体的异常。

我听说将“实体”存储为 NonHibEntity 中的字段(聚合,而不是继承)。但这似乎也很不方便。你怎么认为?什么是合适的解决方案?

最佳答案

A Formula列映射可能适合您的需要。我会先试试这个。

如果这会像您担心的那样导致性能问题,您可以尝试仅在子级中使用此字段的映射类层次结构,并将两者映射到同一个表。不确定这是否真的有效......

作为最后的手段,使用非映射类执行您现在拥有的操作,但将实体作为您其他类中的字段 - 聚合而不是您所说的继承,并确保有一种检索方法从未映射的实体映射实体,以便您可以保存。让它成为 Decorator 是明智的,因此它既是子类又是聚合,您可以继续忽略大部分代码中的区别。

但是,对于未映射的子类和/或聚合,您必须拉出实体才能保存。

关于java - 如何将数据库中计数的属性添加到@Entity 类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4971474/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com