在 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>

在 Nhibernate 中映射两个相同类型的双向集合

如果您选择使用单个映射,则可以将 Rays1 和 Rays2 作为 Rays 列表中的滤镜。

public virtual ICollection Rays1 { return Rays.Where()};