У меня есть базовый класс и два дочерних элемента (A: базовый и B: базовый), и я хочу сопоставить их с двумя таблицами (таблица A и таблица B).Это возможно в Fluent NHibernate?Итак, у меня есть:
public class Base
{
public virtual int Id {get;set;}
public virtual int IndexIn {get;set;}
public virtual Product Product {get;set;}
}
public class A : Base
{
public virtual string Value {get;set;}
}
public class B : Base
{
public virtual int Value {get;set;}
public virtual IList<Sequence> Sequences {get;set;}
}
Мое отображение:
public class BaseMap : ClassMap<Base>
{
public BaseMap()
{
Id(x => x.Id);
Map(x => x.IndexIn);
References(x => x.Product);
}
}
public class AMap : SubclassMap<A>
{
public AMap()
{
Map(x => x.Value);
}
}
public class BMap : SubclassMap<B>
{
public BMap()
{
Map(x => x.Value);
HasMany(x => x.Sequences);
}
}
Но в этом случае создается три таблицы (A, B и Base).Это хорошо, но мне нужно уменьшить количество таблиц, поэтому я могу использовать поля Base в таблицах A и B.Обычно я хочу просто отобразить A и B как обычные классы (без использования наследования), но мне нужно иметь возможность добавить какой-то другой класс, где я могу иметь свойство:
public virtual IList<Base> ListofAandB {get;set;}
Если я удалю определение BaseMapи просто сопоставить A и B как ClassMap <> Я получаю ошибку «Не удается найти определение карты для Base», если я пытаюсь использовать свойство, которое написано выше.