在 Nhibernate 中映射两个相同类型的双向集合
本文关键字:同类型 集合 两个 Nhibernate 映射 | 更新日期: 2023-09-27 17:56:58
我有一个这样的模型
public class Scene
{
public virtual ICollection<Ray> Rays1 {get; set;}
public virtual ICollection<Ray> Rays2 {get; set;}
}
public class Ray
{
public virtual Scene Parent {get; set;}
}
如果我保持这种方式并将其映射到 2 个一对多关系,就会发生这种情况:
- 创建场景
- 在光线上添加 3 件商品1
- 在光线上添加 2 个项目2
- 提交到数据库
- 从数据库查询场景
现在 Rays1 和 Rays2 都有 5 个元素,因为它们共享相同的父 id
我能想到的唯一解决方案是从 Ray 继承 2 个新类,然后用一对多关系映射每个类。这将在数据库上创建两个单独的表,但它们将具有完全相同的列。只是感觉不对劲...
还有其他可用的解决方案吗?
--编辑--
作为参考,以下是我的映射文件:
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
assembly="PanoMeasurer.Core.Domain"
namespace="PanoMeasurer.Core.Domain">
<class name="Panorama">
<id name="OID" generator="guid.comb"/>
<property name="HeadingBase"/>
<set name="Rays1" cascade="all-delete-orphan">
<key column="PanoramaId" />
<one-to-many class="Ray"/>
</set>
<set name="Rays2" cascade="all-delete-orphan">
<key column="PanoramaId" />
<one-to-many class="Ray"/>
</set>
</class>
</hibernate-mapping>
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
assembly="PanoMeasurer.Core.Domain"
namespace="PanoMeasurer.Core.Domain">
<class name="Ray">
<id name="OID" generator="guid.comb"/>
<property name="Heading"/>
<property name="Elevation"/>
<many-to-one name="Owner" class="Panorama" column="PanoramaId" />
</class>
</hibernate-mapping>
如果您选择使用单个映射,则可以将 Rays1 和 Rays2 作为 Rays 列表中的滤镜。
public virtual ICollection Rays1 { return Rays.Where()};