我在为以下模型结构开发一组理智的Fluent NHibernate映射时遇到了问题:
public class BaseLookup
{
public virtual int Id {get; set;}
public virtual string Code {get; set;}
public virtual string Value {get; set;}
public virtual bool Active {get; set;}
}
public class Subdivision : BaseLookup { }
public class AvisCode : BaseLookup { }
public class District : BaseLookup { }
/*etc.*/
这些查找都共享属性,但彼此之间没有任何关系。这些表对报告具有特殊的语义含义,并将在存储过程中专门引用,因此我不希望将它们混合到一个需要我使用鉴别器的常见“查找”表中。这似乎消除了映射中的每层次表和每子类表策略。我也很难使用Table-per-Concrete-Class,因为每个查找都有自己的标识列 - 我不想在应用程序中手动分配Id,并且不要求Id在所有这些中都是唯一的表。
此时,我的映射看起来像这样,并且对于BaseLookup的每个超类都是相同的:
public class AvisCodeMap : ClassMap<AvisCode>
{
public AvisCodeMap()
{
Schema(Schemas.pva.ToString());
Id(x => x.Id).GeneratedBy.Identity();
Map(x => x.Code).Not.Nullable();
Map(x => x.Value).Not.Nullable();
}
}
是否没有允许我将重复映射提取到可重用代码块的映射约定?
答案 0 :(得分:1)
如果我理解你的问题,你可能需要创建一个通用基类映射,然后在派生映射中重用它。
示例如下:
public class BaseLookupMap<T> : ClassMap<T> where T : BaseLookup
{
public BaseLookupMap()
{
// ... base mapping code goes here ...
}
}
创建该基本类型:
public class BaseLookupMap : BaseLookupMap<BaseLookup>
{
}
派生类映射:
public class AvisCodeMap : BaseLookupMap<AvisCode>
{
public AvisCodeMap()
{
Polymorphism.Explicit();
// ... your other mappings here, if needed ...
}
}
HTH。