我目前有以下(简化的)类/数据库模式:
Entity Prospect Customer
+- Id +- Id +- Id
+- Address +- Entity +- Entity
+- Name +- ... +- ...
+- ...
ENTITY PROSPECT CUSTOMER
====== ========== ========
ID - INT PK ID - INT PK ID - INT PK
ADDRESS - VARCHAR ENTITY_ID - INT FK ENTITY_ID - INT FK
NAME - VARCHAR ...
...
以及以下流畅的映射:
PROSPECT_MAP:
Table("PROSPECT");
Id(x => x.Id).GeneratedBy.Increment();
References(x => x.Entity).Cascade.All().Fetch.Join().Column("ENTITY_ID");
...
CUSTOMER_MAP:
Table("CUSTOMER");
Id(x => x.Id).GeneratedBy.Increment();
References(x => x.Entity).Cascade.All().Fetch.Join().Column("ENTITY_ID");
...
现在还有一堆东西附加到实体上(使用 entity_id 作为 FK)。在我的应用程序中,潜在客户可以成为客户。
因此,我想创建一个新客户,将其链接到前潜在客户使用的 entity_id(以便与该实体相关的所有信息现在都属于客户),然后从数据库中删除潜在客户(所以基本上只需删除来自潜在客户表的条目,而不是级联到其子组件,这些子组件现在由新创建的客户链接)
NHibernate 有可能吗?请注意,我需要 ProspectMap 中的 cascade.all,因为删除潜在客户及其组件应该仍然是应用程序中的一个选项。
非常感谢。