我有一个包含多个表的继承类结构。我的班级结构如下。 (这不是真正的类。我创建了假类,这里模仿原文以节省空间。)
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.
答案 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>
我认为可能是鉴别条款可能有帮助和过度使用。 :)没有它工作正常。