0

大多数对此 NHibernate 错误的引用(在标题中)都谈到子对象被删除,同时仍包含在父集合中,该父集合只会在以后重新保存它们,否定它们的“删除”(这是错误状态和建议的内容)从正在重新保存它的关联中删除对象)。

但在我的情况下,删除父记录时发生错误(然后通过关联删除“子”,所以我不希望删除关联,如错误所示)

如果每次都发生这种情况是有道理的,但我只是间歇性地观察到这个错误,运行完全相同的代码,但只针对特定记录。其他相同的记录不会触发条件并且删除会通过(我一直Customer用两个address-es处理一个。)

不确定要显示多少和显示什么代码。这是我的“父”对象映射:

我有一个 OneCustomer-to-ManyAddresses 关系映射为一组 CustomerAddress “复合元素”

<class name="Customer" table="Customer">
        <id name="Id" column="[Id]" type="Guid">
            <generator class="guid" />
        </id>
        ...
        <set name="AddressList" lazy="true" table="CustomerAddress" cascade="all-delete-orphan" >
            <key column="[CustomerId]"/>
            <composite-element class="CustomerAddress">
                <parent name="Customer"/>
                <many-to-one name="Address"
                class="Address"
                column="[AddressId]"
                not-null="true"
                cascade="all"/>
                ...
            </composite-element>
        </set>

这是“复合”对象的映射CustomerAddress

<class name="CustomerAddress" table="CustomerAddress" >
        <id name="Id" column="[Id]" type="Guid">
            <generator class="guid" />
        </id>
        <many-to-one
            name="Address"
            column="[AddressId]"
            class="Address"
            not-null="true"
            cascade="all"/>

        <many-to-one
            name="Customer"
            column="[CustomerId]"
            class="Customer"
            not-null="true"
            cascade="all"/>
            ...
    </class>

错误的解释及其间歇性的性质是什么?

附加信息

经过进一步检查 - 寻找可能包含对同一“地址”子项的引用的另一个集合,我看到了以下映射:

<class name="Address" table="Address">
        <id name="Id" column="[id]" type="Guid" >
            <generator class="guid" />
        </id>

        <!-- REMOVING THE FOLLOWING <BAG> SEEMS TO BE FIXING MY ISSUE -->
        <bag name="CustomerAddressList" inverse="true" cascade="none" lazy="false" >
            <key>
                <column name="[AddressId]" />
            </key>
            <one-to-many class="CustomerAddress" />
        </bag>

    </class>

删除<bag name="CustomerAddressList"...似乎可以解决我的问题。解释?

4

2 回答 2

1

我来猜一猜:

您有一个双向关联,但您没有指定其中之一是非所有者(通过设置“inverse = true”)。

尝试修改 CustomerAddress 关系如下:

<class name="CustomerAddress" table="CustomerAddress" >
    <id name="Id" column="[Id]" type="Guid">
        <generator class="guid" />
    </id>
    <many-to-one
        name="Address"
        column="[AddressId]"
        class="Address"
        not-null="true"
        cascade="all"/>

    <many-to-one
        name="Customer"
        column="[CustomerId]"
        class="Customer"
        not-null="true"
        cascade="all"
        inverse="true"
         />
        ...
</class>
于 2013-07-16T02:26:12.300 回答
0

为什么您有两个 CustomerAddress 表的映射(一个作为复合元素,一个作为实体)?删除客户地址的实体映射,它应该可以工作。

于 2013-07-15T19:57:51.007 回答