3

假设我有一个班级 Foo。我对 Foo 也有一个名为 Foo_Foo 的视图,它列出了 Foo 之间的多对多关联。我将此关联映射为每个 Foo 上的简单不可变集,其中 cascade="none":

<set name="association" table="Foo_Foo" cascade="none" mutable="false">
  <key column="ParentFoo" />
  <many-to-many class="Foo, MyAssembly" column="BaseFoo" />
</set>

但是,当我尝试删除 Foo 时,NHibernate 尝试并正确地未能删除 Foo.association。

如何防止 NHibernate 尝试删除与视图的关联?

4

1 回答 1

2

该集合属于Foo。您无法共享该集合,因此无需将其保存在数据库中。Cascade 用于告诉 NH 引用Foo的 s 是否也应该被删除。

为什么要将Foo_Foo记录保存在数据库中?如果这应该是双向的多对多自引用,它就不会像这样工作。


在理解问题后进行编辑。

Cascade 在您的情况下不起作用,因为它只影响引用的 Foos。

为避免集合表的插入/更新和删除,您可以尝试以下方法之一:

  • 第一个明显的尝试是mutable="false",您已经尝试过。我真的不明白为什么它不起作用。您可以在 Nhibernate 用户组中询问。
  • 不太明显,但很有希望的是inverse="true"。Inverse 告诉 NH 集合映射到其他地方,不需要从这里存储。所以它只是省略了插入,但我不知道删除。
  • 如果这不起作用,您需要探索更复杂的解决方案。您可以将其映射为引用 Foos 的一对多中间实体。中间实体是到视图的映射。它是不可变的(仍然可能导致删除语句)。在这种情况下,cascade="false"将起作用(因为它是被引用的实体)。它也可以配置插入、更新和删除 sql 语句(它们是空的),但这很可能甚至没有必要。
于 2012-10-03T05:50:21.660 回答