我有一个简单的每子类表继承与下面的NHibernate映射
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" default-access="property" auto-import="true" default- cascade="none" default-lazy="true">
<class xmlns="urn:nhibernate-mapping-2.2" mutable="true" name="BillingDetail table="BillingDetails">
<id name="Id" type="System.Int32">
<column name="Id" />
<generator class="identity" />
</id>
<property name="DateAdded" type="System.DateTime">
<column name="DateAdded" />
</property>
<many-to-one class="Account name="Account">
<column name="Account_id" />
</many-to-one>
<joined-subclass name="BankAccount table="BillingDetails_BankAccount">
<key>
<column name="Id"/>
</key>
<property name="AccountNumber" type="System.Int64">
<column name="AccountNumber" />
</property>
<property name="SortCode" type="System.Int32">
<column name="SortCode" />
</property>
</joined-subclass>
<joined-subclass name="CreditCard table="BillingDetails_CreditCard">
<key>
<column name="Id" />
</key>
<property name="CardNumber" type="System.Int64">
<column name="CardNumber" />
</property>
<property name="CardType" type="System.String">
<column name="CardType" />
</property>
<property name="ExpiryDate" type="System.DateTime">
<column name="ExpiryDate" />
</property>
</joined-subclass>
</class>
</hibernate-mapping>
因此信用卡和银行账户都继承自“账单明细”。在我的域层中,我有以下声明:
var billingDetail = (from a in unitOfWork.Context.BillingDetail.OfType<CreditCard>()
select a).FirstOrDefault();
上面的“unitOfWork.Context”属性只允许我访问ISession工作单元。当我运行应用程序时,我收到以下错误:
BillingDetail ='unitOfWork.Context.BillingDetail'引发了'NHibernate.PropertyAccessException'类型的异常 Message =“Invalid Cast(检查映射中的属性类型不匹配); BankAccount的setter”
如果我在“var billingDetail ...”语句中放置一个断点并运行程序来检查此错误,我可以看到上面的消息。但是,如果我然后单击“播放”继续执行程序,而不是使用上述消息进行轰炸,程序将成功运行并将所有数据输入数据库。在没有检查breakpount的情况下,程序崩溃了(正如我预期的那样,如果映射确实存在问题)。
似乎正在发生的事情是每次看到“BankAccount”实体都给出例外,但所有CreditCard实体都没有问题。 “OfType”是否有问题,它没有过滤掉BankAccount对象?
答案 0 :(得分:0)
这里的回答没什么有趣的。我应该更加注意所说的全部错误:
无效的转换(检查您的映射是否存在属性类型不匹配)
当我做错误告诉我的时候,我看到一个列被映射为Int32但应该是Int64的列。我不是很聪明。