0

我目前有以下(简化的)类/数据库模式:

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,因为删除潜在客户及其组件应该仍然是应用程序中的一个选项。

非常感谢。

4

1 回答 1

1
void UpgradeToCustomer(Prospect p)
{
    var customer = new Customer
    {
        Entity = p.Entity
    };

    p.Entity = null; // prevent cascading

    session.Delete(p);
    session.Save(customer);
}
于 2012-05-25T07:13:22.633 回答