NHibernate多对一关联拒绝加载

时间:2009-10-30 12:59:01

标签: nhibernate criteria orm

我有以下映射,多对一属性'Message'在'RootMessage'类中具有相应的一对多关联。

<class name="IMessageReceipt" lazy="false" table="MessageReceipts" abstract="true">

        <id name="Id">
            <generator class="guid.comb"></generator>
        </id>

        <discriminator column="Discriminator"/>
        <property name="Address" />
        <property name="Status" />
        <property name="MarkedAsDeleted" />

        <many-to-one name="Message" column="MessageId" class="RootMessage" 
                not-found="ignore"/>

        <subclass name="MessageReceipt" lazy="false" discriminator-value="1">
        </subclass>

    </class>

当使用条件api时,多对一关联拒绝加载(我得到的全部是NULL),这是一个查询示例:

            List<IMessageReceipt> list;
        using (var tx = Session.BeginTransaction())
        {
            var criteria = Session.CreateCriteria(typeof (IMessageReceipt));
            criteria.Add(Restrictions.Eq("Address", address));
            criteria.Add(Restrictions.Eq("Status", status));
            criteria.SetFirstResult(0);
            criteria.SetMaxResults(quantity);
            list = criteria.List<IMessageReceipt>().ToList();
            tx.Commit();
        }
        return list;

有什么想法吗?

1 个答案:

答案 0 :(得分:1)

好吧,经过近一天的懊恼,我得到了解决方案。即使您在两个之间存在映射,NHibernate也不会自动假设两个实体之间的双向关联。在持久化之前,您需要在代码中强制声明关联。因此:

message.Receipts = receipts;
foreach (var receipt in receipts)
{
   receipt.Message = message;
}
Session.Save(message);
tx.Commit();

还应将inverse =“true”应用于具有集合成员的一侧:

<set name="Receipts" inverse="true" cascade="save-update">
<key column="MessageId"></key>
<one-to-many class="IMessageReceipt"/>
</set>