流畅的NHibernate映射 - 复合键

时间:2010-07-06 17:54:07

标签: fluent-nhibernate nhibernate-mapping s#arp-architecture automapping composite-id

我正试图在FNH中映射下面的表/实体,似乎无处可去!

**Tables**
Contacts
    ID (PK - int - generated)
    ...

PhoneTypes
    ID (PK - varchar - assigned) (e.g. MOBILE, FAX)

ContactPhones
    ContactRefId    (PK - FK to Contacts)
    PhoneTypeRefId  (PK - FK to PhoneTypes)
    ...

(我应该注意到我也在使用S#arp架构框架)

**Entities**
public class Contact : Entity
{
    (The ID property is defined in the Entity base class and is type int)

    public virtual ICollection<ContactPhone> PhoneNumbers { get; set; }
}

public class PhoneType : EntityWithTypedId<string>, IHasAssignedId<string>
{
    (The ID property is defined in the base class and is type string)

    ....
}

public class ContactPhone : EntityWithTypedId<ContactPhoneId>, IHasAssignedId<ContactPhoneId>
{
    public virtual Contact Contact { get; set; }

    public virtual PhoneType PhoneType { get; set; }
    ....
}

我读到在处理复合id时,建议将复合id分成不同的类是明智的。 hibernate composite key

public class ContactPhoneId : EntityWithTypedId<ContactPhoneId>, IHasAssignedId<ContactPhoneId>
{
    public virtual Contact Contact { get; set; }

    public virtual PhoneType PhoneType { get; set; }
}
...I could just make this class serializable and override 
Equals and GetHashCode myself instead of using the S#arp Arch base class.

我尝试了很多映射组合,现在我已经完全糊涂了。

这是我的最新镜头:

public class ContactMap : IAutoMappingOverride<Contact>
{
    public void Override(AutoMapping<Contact> mapping)
    {
        mapping.HasMany<ContactPhone>(x => x.PhoneNumbers)
            .KeyColumns.Add("ContactRefId")
            .KeyColumns.Add("PhoneTypeRefId")
            .AsSet()
            .Inverse()
            .Cascade.All();
    }
}


public class PhoneTypeMap : IAutoMappingOverride<PhoneType>
{
    public void Override(AutoMapping<PhoneType> mapping)
    {
        mapping.Id(x => x.Id).Column("Id").GeneratedBy.Assigned();
    }
}


public class ContactPhoneMap : IAutoMappingOverride<ContactPhone>
{
    public void Override(AutoMapping<ContactPhone> mapping)
    {
        mapping.Table("ContactPhones");
        mapping.CompositeId<ContactPhoneId>(x => x.Id)
            .KeyReference(y => y.Contact, "ContactRefId")
            .KeyReference(y => y.PhoneType, "PhoneTypeRefId");
    }
}  

我在尝试生成映射时抛出了很多异常,其中最新的是:

Foreign key (FK672D91AE7F050F12:ContactPhones [ContactRefId, PhoneTypeRefId])) 
must have same number of columns as the referenced primary key (Contacts [Id])

有没有人看到任何明显的我做错了?我是NH和FNH的新手,这篇文章可能很明显。 :-)另外,有没有人在使用S#arp架构时使用像这样的复合ID?什么是最佳实践(除了使用代理键:-))?

非常感谢...并对这篇长篇文章感到抱歉。

2 个答案:

答案 0 :(得分:0)

我也有很多关系。我有这样的设置:

mapping.HasManyToMany(x => x.Artists).Cascade.All().Inverse().Table("ArtistImages");

ArtistImages表具有表格艺术家和图像的主键。

答案 1 :(得分:0)

也许FluentNHibernate无法映射这种关系。您可以尝试使用hbm文件。本文中的示例与您的情况并不完全相同,但它可能足以让您入门。

Fluent NHibernate: How to Map M:N many-to-many with composite keys on both sides