6

场景如下,

我有 3 个名为Parent 的对象(我简化了名称),父母的孩子和孩子的孩子
父母的孩子是父母的集合,孩子的孩子是孩子的集合。

映射如下(相关部分)

父母

<set name="parentset"
     table="pc-table"
     lazy="false"
     fetch="subselect"
     cascade="all-delete-orphan"
     inverse="true">
  <key column=FK_ID_PC" on-delete="cascade"/>
  <one-to-many class="parentchild,parentchild-ns"/>
</set>

父母的孩子

<set name="childset"
     table="cc-table"
     lazy="false"
     fetch="subselect"
     cascade="all-delete-orphan"
     inverse="true">
  <key column="FK_ID_CC" on-delete="cascade"/>
  <one-to-many class="childschild,childschild-ns"/>
</set>

我想要实现的是,当我删除父级时,会一直级联删除到孩子的孩子。但目前发生的事情是这样的。

(这纯粹是为了映射测试目的)获取父实体(工作正常)

IQuery query = session.CreateQuery("from Parent where ID =" + ID);
IParent doc = query.UniqueResult<Parent>();

现在删除部分

session.Delete(doc);
transaction.Commit();

在通过级联和反转解决了“无法插入空值”错误后,我希望现在可以使用此代码删除所有内容,但只有父级被删除。

我是否错过了我的映射中可能会错过的某些内容?任何正确方向的提示都非常受欢迎!


迭戈,谢谢你的中肯回答。(和解释)

我删除了on-delete="cascade",这是因为我喜欢在代码中而不是在数据库中尽可能多地进行控制。

下面发布的代码是(工作)结果。

父母

<set name="parentset"     
     table="pc-table"     
     cascade="all-delete-orphan"     
     inverse="true"
     batch-size="5">     
  <key column=FK_ID_PC"/>     
  <one-to-many class="parentchild,parentchild-ns"/>     
</set>

父母的孩子

<set name="childset"            
     table="cc-table"     
     cascade="all-delete-orphan" 
     batch-size="5"  
     inverse="true">            
  <key column="FK_ID_CC">            
  <one-to-many class="childschild,childschild-ns"/>            
</set>

希望这可以帮助有同样问题的人!

4

1 回答 1

6

通过设置on-delete="cascade"键,您可以让数据库处理级联。

您是否使用 NHibernate 生成架构?

我刚刚复制了您的示例,无论有无该属性,它都可以正常工作。移除它时,NHibernate 会进行级联。

顺便说一句,lazy="false" fetch="subselect"默认情况下使用不是您应该做的事情。如果您删除这些属性,离开on-delete="cascade"并更改cascadesave-update,您将只有两个查询来检索和删除父级。

于 2010-03-05T15:45:22.643 回答