【问题标题】:NHibernate Mapping a sublass property to another object via foreign keyNHibernate 通过外键将子类属性映射到另一个对象
【发布时间】:2011-08-22 12:01:43
【问题描述】:

我正在处理一个不完美的现有数据结构,我有一个继承映射问题要解决。

我使用每个层次结构的表,并设置了带有鉴别器的子类。但是,子类属性是返回到其他表的外键。如何设置我的子类映射,以便在查询 fk 属性时得到一个对象而不是 null?这甚至可能吗?

我当前的映射

<?xml version="1.0" encoding="utf-8" ?>
      <hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="MVC3" namespace="MVC3.Models">
  <class name="Image" table="Images">
<id name="Id" column="ImageId">
  <generator class="identity" />
</id>
<discriminator column="ImageType" />
<property name="Url" column="Url" not-null="true" />
<property name="Caption" column="Caption" />
<subclass name="AupairImage" discriminator-value="AupairImage">
  <join table="Aupairs" inverse="true">
    <key column="AupairId" />
    <many-to-one name="Aupair" column="AupairId" class="Aupair" />
  </join>
</subclass>
<subclass name="FamilyImage" discriminator-value="FamilyImage">
  <join table="Families" inverse="true">
    <key column="FamilyId" />
    <many-to-one name="Family" column="FamilyId" class="Family" />
  </join>      
</subclass>

我想添加一个实体图,但我还不能发布图片:0(

但外键 AupairId 和 FamilyId 链接回另外两个表,并且是 int 32 类型

我知道最好重组 Aupair 和 Family 实体以具有层次结构以摆脱图像中的实体,但由于现有代码,这将是最后的手段。

在此先感谢地图专家的任何帮助......

【问题讨论】:

    标签: nhibernate mapping subclass


    【解决方案1】:

    再看一遍后意识到我做错了什么,应该只是在子类下使用了一个多对一的定义列

        <subclass name="MVC3.Models.FamilyImage, MVC3" discriminator-value="FamilyImage">
         <many-to-one cascade="all" class="MVC3.Models.Family, MVC3" name="Family">
            <column name="FamilyId" />
          </many-to-one>
        </subclass>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2019-04-27
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多