如何在NHibernate中将继承的类映射到db?

时间:2012-11-14 10:25:57

标签: nhibernate c#-4.0 nhibernate-mapping

我有一个包含多个表的继承类结构。我的班级结构如下。 (这不是真正的类。我创建了假类,这里模仿原文以节省空间。)

class Account {
    public virtual int AID { get; set; }
    public virtual string Name { get; set; }
    public virtual string Serial { get; set; }
    public virtual string Type { get; set; }

    public Account { Type = "Default"; }
}

class Human : Account {
    public virtual string FirstName { get; set; }
    public virtual string LastName { get; set; }
    // more properties..

    public Human { Type = "Human"; }
}

class Bank : Account {
    public virtual string BranchName { get; set; }
    // more properties..

    public Bank { Type = "Bank"; }
}

我的Account.hbm.xml文件如下所示。

  <class name="Account">
    <id name="AID" type="Int32">
      <generator class="native" />
    </id>
    <discriminator column="Type" type="string" />
    <property name="Name" />
    <property name="Serial" />
    <property name="Type" />

    <subclass name="Human" discriminator-value="Human">
      <join table="Account">
        <key column="AID" />
        <property name="FirstName" />
        <property name="LastName" />
      </join>
    </subclass>

    <subclass name="Bank" discriminator-value="Bank">
      <join table="Account">
        <key column="AID" />
        <property name="LocationName" />
      </join>
    </subclass>    
  </class>

我执行此操作,并使用正确的字段集创建表。问题是我插入记录。

我是从下面开始的。

Bank bank = new Bank();
bank.Name = "Any Name";
bank.Serial = "0001";
bank.BranchName = "Local CIty";

using (ISession session = NHibernateHelper.OpenSession())
{
    using (ITransaction transaction = session.BeginTransaction())
    {
        session.Save(bank);
        transaction.Commit();
    }
}

以下是NUnit产生的错误。也许我在做错事。有人可以帮我这个吗?

NHibernate.PropertyValueException : Error dehydrating property value for 
xxxx.xxxxx.Bank.Name
  ----> System.IndexOutOfRangeException : Parameter index is out of range.

2 个答案:

答案 0 :(得分:1)

&lt; join&gt; -clause与继承无关。 &lt;子类&gt;元素就够了。这里记录了处理继承的其他方法:http://nhibernate.info/doc/nh/en/index.html#inheritance

答案 1 :(得分:1)

我用cluase修改了Account.hbm.xml映射文件。现在事情很好。我现在可以顺利地插入记录而没有任何错误。

这是工作映射文件。

  <class name="Account">
    <id name="AID" type="Int32">
      <generator class="native" />
    </id>
    <!-- <discriminator column="Type" type="string" /> -->
    <property name="Name" />
    <property name="Serial" />
    <property name="Type" />

    <joined-subclass name="Human" table="Human">
      <key column="AID" />
      <property name="FirstName" />
      <property name="LastName" />
    </subclass>

    <joined-subclass name="Bank" table="Bank">
      <key column="AID" />
      <property name="LocationName" />
    </subclass>    
  </class>

我认为可能是鉴别条款可能有帮助和过度使用。 :)没有它工作正常。