还有一个关于“删除的对象将通过级联重新保存(从关联中删除已删除的对象)”

时间:2013-07-15 19:41:11

标签: nhibernate

大多数对这个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"...似乎解决了我的问题。解释

2 个答案:

答案 0 :(得分: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>

答案 1 :(得分:0)

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